C#如何使用数据库
来源:互联网 发布:颈椎病运动疗法知乎 编辑:程序博客网 时间:2024/06/08 12:46
数据库,在我们开发项目中那是最常见的了,无论复杂的项目、还是简单的项目,只要涉及数据的操作(增删改查),都会用到数据库。当然使用的数据库的种类根据项目的需求不同,也是不同的。在我所做的项目中就是用过ACCESS 2000、SQL Server 2000、Oracle 10g,因此简单总结下c#如何使用数据库的。程序执行sql语句(包括单条sql,多条sql,存储过程,函数等等)大体有三个步骤:连接数据库,执行sql语句,返回结果。那么我们来看看c#是如何完成这三个步骤的。无论哪种数据库都是这三个步骤,那么就不按数据库分了,按照返回结果的类型来分类吧。
数据库连接用的字符串:
即下面代码的connstr
"Provider=Microsoft.Jet.OLEDB.4.0;Data Source="数据库路径";Persist Security Info=True;Jet OLEDB:Database Password="密码"
1、 执行sql语句返回受影响的行数
(1)、一条sql语句
public static int ExecuteNonQuery(string connStr, string sql) { OleDbConnection conn = null; try { conn = new OleDbConnection(connStr); conn.Open(); OleDbCommand command = new OleDbCommand(sql, conn); return command.ExecuteNonQuery(); } catch { return 0; } finally { if (conn != null) conn.Close(); } }
(2)、多条sql语句,返回受影响行数。由于多条sql为了保证数据库的正确性,最好使用事务方式运行。
public static int ExecuteNonQuery(string connStr, List<string> sqlList) { int executeCount = 0; OleDbTransaction transaction = null; OleDbConnection conn = null; try { conn = new OleDbConnection(connStr); conn.Open(); transaction = conn.BeginTransaction(); OleDbCommand command = new OleDbCommand(); command.Connection = conn; command.Transaction = transaction; for (int i = 0; i < sqlList.Count; i++) { command.CommandText = sqlList[i]; executeCount += command.ExecuteNonQuery(); } transaction.Commit(); } catch { if (transaction != null) transaction.Rollback(); return 0; } finally { if (conn != null) conn.Close(); } return executeCount; }
2、返回DataSet
public static DataSet ExecuteQueryReturnDataSet(string connStr, string sql) { OleDbConnection conn = null; DataSet ds = null; try { conn = new OleDbConnection(connStr); ds = new DataSet(); conn.Open(); OleDbDataAdapter command = new OleDbDataAdapter(sql, conn); command.Fill(ds, "datasetName"); } catch { } finally { if (conn != null) conn.Close(); } return ds; }
3、返回OleDbDataReader
public static OleDbDataReader ExecuteQueryReturnReader(string sql, string connStr) { OleDbConnection conn = new OleDbConnection(); OleDbDataReader reader = null; try { conn = new OleDbConnection(connStr); conn.Open(); OleDbCommand command = conn.CreateCommand(); command.CommandText = sql; reader = command.ExecuteReader(); } catch { } finally { if (conn != null) conn.Close(); } return reader; }
4、执行存储过程并返回受影响行数(以Oracle为例)
public static int RunProcedure(string storedProcName, IDataParameter[] parameters) { int result = 0; try { using (OracleConnection connection = new OracleConnection(GetConnectionString())) { connection.Open(); OracleCommand command = BuildQueryCommand(connection, storedProcName, parameters); result = command.ExecuteNonQuery(); } } catch (Exception e) { } return result; } private static OracleCommand BuildQueryCommand(OracleConnection connection, string storedProcName, IDataParameter[] parameters) { OracleCommand command = new OracleCommand(storedProcName, connection); command.CommandType = CommandType.StoredProcedure; foreach (OracleParameter parameter in parameters) { command.Parameters.Add(parameter); } return command; }
5、带参数的sql语句
public static int ExecuteNonQuery(string sql,string connStr, OleDbParameter[] commandParameters) { int count = 0; OleDbCommand cmd = new OleDbCommand(); OleDbConnection conn = null; try { conn = new OleDbConnection(connStr); PrepareCommand(cmd, conn,sql, commandParameters); count = cmd.ExecuteNonQuery(); cmd.Parameters.Clear(); } catch { } finally { if (conn != null) { conn.Close(); } } return count; } private static void PrepareCommand(OleDbCommand cmd, OleDbConnection conn, string sql, OleDbParameter[] cmdParms) { if (conn.State != ConnectionState.Open) conn.Open(); cmd.Connection = conn; cmd.CommandText = sql; cmd.CommandType = CommandType.Text; if (cmdParms != null) { foreach (OleDbParameter parm in cmdParms) cmd.Parameters.Add(parm); } }
一般常用的就这么几种,数据库的几个重要对象分别是:OleDbCommand、OleDbConnection、OleDbDataReader、OleDbDataAdapter、DataSet。对于不同数据库,有几个对象需要对应相应数据库的对象。OleDbCommand、OleDbConnection、OleDbDataReader、OleDbDataAdapter,Oracle下OleDb换成Oracle,Sql Server下 则换成SQL。
你还可能感兴趣:c#调用oracle存储过程 Oracle存储过程的格式 c#如何使用webservice、存储过程及存储过程的创建(简单模仿类似QQ统计用户在线时间为例)
- C#如何使用数据库
- C#如何使用数据库
- C#如何使用数据库
- 【转载】C#如何使用数据库
- 如何使用C#连接dbf数据库
- 如何使用c#操作SQLite数据库
- 如何使用C#监听SQL Server数据库
- C# 如何使用 Sql Server Compact 数据库
- C#中如何使用SQLite数据库
- C#如何备份数据库
- 如何使用 Visual C# .NET 从 DataSet 对象更新数据库
- 如何使用C#创建一个三层的数据库应用程序
- 如何使用C#创建一个三层的数据库应用程序
- C#如何使用ACCESS数据库字段填充Combobox
- 如何使用ADO.Net助手生成C#数据库代码
- C#使用SQLite数据库
- C#数据库的使用
- c#使用access数据库
- oracle 级联更新
- 病毒的手工排除与分析(更新完毕)
- 代码点与代码单元
- 14个华丽的javascript图表资源和插件
- ::的意义(小知识)VC里::后跟函数什么意思
- C#如何使用数据库
- 地址译码电路设计实验
- oracle TM锁和TX锁
- linux后台执行程序,& nohup
- python re模块用法总结
- work之成员
- sqlpus报错"ORA-01033: ORACLE initialization or shutdown in progress",且数据库状态是"ORA-01507: database not m
- 30年来长篇小说
- jquery ajax调用不刷新页面