#T#经过长时间学习ADO.NET数据库,在网上也收集了许多资料,看完本文你肯定有不少收获。首先***个要说的是DBConnection,它的作用是相当于在程序与数据库服务器之间建立一条的通路,因此缺少了它,那么所有对数据库的操作都变成空谈。在对DBConnection对象进行操作的时候,要注意如下几点:
设置ConnectionString(连接字符串),这好比选择路径的方向,如果方向不对,则无法建立通路。对于不同数据库,其连接字符串设置也不同,以下列举说明。ADO.NET数据库连接字符串:
- SQL Server
- data source=数据库服务器名;
- initiacatalog=数据库名;
- user id=连接用户名;
- password=密码;
- Access
- Provider=Microsoft.JET.OLEDB.4.0;
- data source=数据库文件名(指明路径);
- user id=Admin;Jet OLEDB:Database Password=密码;
备注:“Jet OLEDB:Database Password=密码;”这部分是可选的,即如果没有密码的话,去掉这部分即可。
调用Open与Close方法,来打开数据库连接和关闭数据库连接,由于数据库连接会出现异常,因此要用TRY-CATCH来进行捕获。通过State属性来查看当前数据库连接的状态。例如:假如在一段时间内不操作数据库,数据库连接很有可能会被系统关闭,因此在每次数据库操作的时候,***先判断一下数据库连接的State属性,例如在SQL Server中可以如下:
- if(sqlConn.State==ConnectionState.Closed||sqlConn.State==ConnectionState.Broken)
- //Connection is not available
- return false;
- else
- //Connection is available
- return true;
当ADO.NET数据库 可以连接是通的情况下,再进行数据库操作。接下来就要说说DBCommand这个类,所有对数据库的操作都是通过它进行完成的。如果把DBConnection比作通路的话,那么 DBCommand就是在这条通路上来回跑动的车辆。缺少了它,在程序中所有对数据库的操作无法传递给ADO.NET数据库服务器端。因此可以说,DBConnection和DBCommand组成ADO.NET的基础。在对DBCommand对象进行操作的时候,需要注意如下几点。
设置CommandText和CommandType属性,一般情况下是不需要设置CommandType属性,但是如果执行存储过程,则需要设置CommandType属性为StoredProcedure.建议多使用参数,而减少字符串的拼接,这样一是可以减少程序书写错误,而可以避免语句蛀虫。参数的使用可以如下:
- SqlCommand myComm = new SqlCommand();
- myComm.CommandText = “SELECT * FROM UserInfo WHERE UserName = @UserName ”;
- myComm.Parameters.Add( “@UserName”, yourValue );
区分ExecuteNonQuery方法和ExecuteReader方法,前者是主要是处理非查询类型的语句,返回的个数是受影响的个数,但其对“INSERT”语句是不起任何作用的;而后者主要是处理查询语句,但是需要借助DataReader来辅助操作。***不要忘了在用完后,调用Dispose方法对DBCommand对象进行释放。