近日和小火伴们在进行机房合作,我负责的是D层。在重新写sqlhelper时,发现查询操作用到的是SqlDataAdapter对象,我记得还有个SqlDataReader对象也是履行对数据库的查询操作。还有增删改方法除ExecuteNonQuery()还有无其他方法,返回值integer和boolean有甚么不同。个人重构时没好好研究,现在好好总结1下,欢迎各位斧正。
我们在对数据库进行增删改操作时1般使用sqlcommand命令对象,这个对象的方法有3个。非别是ExecuteNonQuery()、ExecuteReader()、ExecuteScalar()。其中ExecuteNonQuery();它的返回值类型为int型。多用于履行增加,删除,修改数据。返回受影响的行数。
具体来讲,此方法用于履行任何不从数据库返回结果集的SQL操作命令,包括INSERT INTO、UPDATE、DELETE语句、没有返回数值的存储进程、CREATE TABLE和CREATEINDEX之类的DDL语句。ExecuteNonQuery方法对UPDATE、INSERT INTO和DELETE这些操作语句,其返回值为该命令所影响的行数。对所有其他类型的语句,返回值为⑴。如果产生回滚,返回值也为⑴。所以如果让其履行查询语句,返回值为⑴,无意义。我在个人重构时返回的是Boolean型。实际上是1样的,当返回值为非零时,说明数据库中受影响的行不为零,所以履行增删改操作True. 当返回值为零或负值时,说明该操作没有履行成功。
我们知道sqlcommand对象中有2个查询的方法,分别是ExecuteReader()、ExecuteScalar(),但是我们在写sqlhelper时1般用到的是SqlDataAdapter对象,这3者有甚么不同呢?
ExecuteScalar()返回1个int型变量。如果SQL语句是Select查询,则仅仅返回查询结果集中第1行第1列,而疏忽其他行和列。如果SQL语句不是Select查询,则这个返回结果没任何作用。由于不知道sql语句究竟是甚么样的结构(有多是int,有多是Char等其它,)所以ExecuteScalar()方法返回1个最基本的类型Object,这个类型是所有类型的基类,可以转换为任意类型,所以用前需强迫转换。
ExecuteReader 返回1个DataReader对象,如果在SqlCommand对象中调用,则返回SqlDataReader,如果在OledbCommand对象中调用,返回的是OledbDataReader,可以调用DataReader的方法和属性迭代处理结果集。ExecuteReader方法存在的目的:尽量快的对数据库进行查询并得到结果。
还有SqlDataAdapter对象,下面主要讲它和SqlDataReaderr的区分。
我们重构都用SqlDataAdapter+DataSet。SqlDataReader咋了,招谁惹谁了,为啥没人用。这实际上是适合不适合的问题,就像电视剧中常常出现的那句台词“你是个好人,但是我们不适合”。他俩具体合适哪些情况呢。
1.SqlDataReader //基于连接,只读访问合适数据量较小。(连接模式)
SqlDataAdapter //基于非连接,适于数据量较大时,可以另行修改,最后再把修改结果返回给数据库。要求资源也大1点 (断开模式)
2.SqlDataAdapter 读取数据后将数据集放入DataSet ,DataSet 的数据存在本地客服机内存。
3.SqlDataReader返回的是1个数据读写器,只能1条条的读,操作起来不灵活,1般在只读的时候才用到。
SqlDataAdapter返回的是数据集或表,可以对其中的数据作任意操作
4.写法上不同:
SqlDatReader履行前须先打开数据库,然后须生成1个command对象。再由command.ExecuteReader()方法赋值。完成后须手动关闭联接。
SqlCommand cmd = newSqlCommand("select * from stu", conn);
conn.Open();
SqlDataReader rdr= cmd.ExecuteReader();
conn.close();
SqlDataAdapter 履行时,自动打数据库,且不用Command的ExecuteReader方法进行赋值,完成后自动断开联接。
SqlDataAdapteradptr = new SqlDataAdapter(sql, conn);
DataSet ds = newDataSet();
adptr.Fill(ds,"stu");
回想1年前就看了红皮书,就简单了解了触及SQLSERVER数据库操作的7个对象,对现在每次遇到时都有新的收获。觉自己知之甚少,叹其之强大。