您好,欢迎访问一九零五行业门户网

关于增删改查的几个对象及方法

近日和小伙伴们在进行机房合作,我负责的是d层。在重新写sqlhelper时,发现查询操作用到的是sqldataadapter对象,我记得还有个sqldatareader对象也是执行对数据库的查询操作。还有增删改方法除了executenonquery()还有没有其他方法,返回integer和boolean有
近日和小伙伴们在进行机房合作,我负责的是d层。在重新写sqlhelper时,发现查询操作用到的是sqldataadapter对象,我记得还有个sqldatareader对象也是执行对数据库的查询操作。还有增删改方法除了executenonquery()还有没有其他方法,返回值integer和boolean有什么不同。个人重构时没好好研究,现在好好总结一下,欢迎各位斧正。
一、增删改的方法
我们在对数据库进行增删改操作时一般使用sqlcommand命令对象,这个对象的方法有三个。非别是executenonquery()、executereader()、executescalar()。其中executenonquery();它的返回值类型为int型。多用于执行增加,删除,修改数据。返回受影响的行数。
具体来说,此方法用于执行任何不从数据库返回结果集的sql操作命令,包括insert into、update、delete语句、没有返回数值的存储过程、create table和createindex之类的ddl语句。executenonquery方法对于update、insert into和delete这些操作语句,其返回值为该命令所影响的行数。对于所有其他类型的语句,返回值为-1。如果发生回滚,返回值也为-1。所以如果让其执行查询语句,返回值为-1,无意义。我在个人重构时返回的是boolean型。其实是一样的,当返回值为非零时,说明数据库中受影响的行不为零,所以执行增删改操作true. 当返回值为零或负值时,说明该操作没有执行成功。
二、查询的方法 我们知道sqlcommand对象中有2个查询的方法,分别是executereader()、executescalar(),但是我们在写sqlhelper时一般用到的是sqldataadapter对象,这三者有什么不同呢?
executescalar()返回一个int型变量。如果sql语句是select查询,则仅仅返回查询结果集中第一行第一列,而忽略其他行和列。如果sql语句不是select查询,则这个返回结果没任何作用。由于不知道sql语句到底是什么样的结构(有可能是int,有可能是char等其它,)所以executescalar()方法返回一个最基本的类型object,这个类型是所有类型的基类,可以转换为任意类型,所以用前需强制转换。
executereader 返回一个datareader对象,如果在sqlcommand对象中调用,则返回sqldatareader,如果在oledbcommand对象中调用,返回的是oledbdatareader,可以调用datareader的方法和属性迭代处理结果集。executereader方法存在的目的:尽可能快的对数据库进行查询并得到结果。
还有sqldataadapter对象,下面主要讲它和sqldatareaderr的区别。
三、sqldatareader与sqldataadapter的区别
我们重构都用sqldataadapter+dataset。sqldatareader咋了,招谁惹谁了,为啥没人用。这其实是合适不合适的问题,就像电视剧中经常出现的那句台词“你是个好人,但是我们不合适”。他俩具体适合哪些情况呢。
1.sqldatareader //基于连接,只读访问适合数据量较小。(连接模式)
sqldataadapter //基于非连接,适于数据量较大时,可以另行修改,最后再把修改结果返回给数据库。要求资源也大一点 (断开模式)
2.sqldataadapter 读取数据后将数据集放入dataset ,dataset 的数据存在本地客服机内存。
3.sqldatareader返回的是一个数据读写器,只能一条条的读,操作起来不灵活,一般在只读的时候才用到。
sqldataadapter返回的是数据集或者表,可以对其中的数据作任意操作
4.写法上不同:
sqldatreader执行前须先打开数据库,然后须生成一个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);
四、总结 回想一年前就看了红皮书,就简单了解了涉及sqlserver数据库操作的7个对象,对现在每次遇到时都有新的收获。觉自己知之甚少,叹其之强大。
其它类似信息

推荐信息