ado知识遗补

1.CommandBehavior类
这个类与Sqldataread相关,比如:
SqlDataReader rdr = cmd.ExecuteReader(CommandBehavior.CloseConnection);
这个rdr是一般是要返回外调用者,那他调用完后怎么去关闭数据库连接呢?如果象上面这样写,在调用者rdr.close()时会自动关闭数据库,省事省心啊

2.DataAdapter.TableMappings 属性
如果一个DataAdapter返回的是多个记录集,默认的情况下,Fill(DataSet ds)后ds中的第一个表名是Table,第二个表是Table1,第三个是Table2。如果用了TableMappings,那么这些Table,Table1,Table2就可以用TableMappings中指定的名称了。比如:
sqlAda = new SqlDataAdapter();
sqlAda.TableMappings.Add("Table", "orders");
sqlAda.TableMappings.Add("Table1", "employees");
...
ds = new DataSet();
sqlAda.Fill(ds);

这时ds.Tables[0].TableName为orders,ds.Tables[1].TableName为employees;这样就方便了按句子取一个表,比如DataTable orders=ds.Tables["orders"];
需要说明的是"Table","Table1"...是固定的名称,不可乱写哈!

3.SqlDataAdapter.Update方法
这里用的是ado.net的断开模式,就是说所有的数据更改在dataset中完成,然后一次性提交到数据库中
首先要这样做:
SqlConnection con = new SqlConnection(@"server=.\ljzforever;database=test;uid=sa;pwd=ljz");
SqlDataAdapter dap=new SqlDataAdapter("select * from a", con);SqlCommandBuilder scb = new SqlCommandBuilder(dap);
用SqlCommandBuilder将SqlDataAdapter打包一下,其实你提交回数据库的时候,本质提交的还是用Sql脚本,这个类的作用是对比dataset与数据库中的数据,当数据不一致的时候自动将改动的地方自动生成sql脚本提交,而不用自手动来写
dap.Fill(ds);
这样数据库进Dataset了
当dataset中的数据有更改时,比如加了一行
ds.Tables[0].Rows.Add("111", "zzz");
你需要把数据提交数据库,真正的增加一行,就要这样:
dap.Update(ds);
这行的意思是提交,这样,内存中改动的部份就真正反映到数据库中了

4.DataSet.AcceptChanges 方法与 SqlDataAdapter.Update
DataSet.AcceptChanges只是在内存在对数据向DataSet提交
SqlDataAdapter.Update才是真正将变化反映到数据库中了
Update要用在AcceptChanges之前,因为使用数据集的数据操作方式是断开与数据库连接的,也就是说只是在得到数据库数据的副本后立即断开了与数据库的连接。你无法保证你的数据是最新的(你不知道是否其他用户在你FILL后是否有修改了数据),所以update也不一定成功。即便成功了,你也没有刷新数据,你仍然不能得到最新的数据。如果你先acceptchange,那么这些行的状态就改变了,这样他们将不能得到更新,因为update方法是根据行的状态进行更新的。你在update成功后acceptchange只能保证你现有的能看到的数据是正确的(这也是暂时的和不确定的)。
所以:
当调用 Datatable.AcceptChanges后再调用Adapter.Update将不会有记录更新到服务器中的记录了,因为调用Datatable.AcceptChanges所有行DataRowState也会随之更改:所有状态为Added和Modified的行的状态都变为Unchanged;状态为Deleted的行则被移除
反过来如果Adapter.Update后如果不调用Datatable.AcceptChanges,那么所有行DataRowState不会有什么更改,下次如果再调用Adapter.Update还会有与上次Adapter.Update相同记录更新到数据库中。
Adapter.Update 会自动调用dataset的AcceptChanges
还有两个属性:
AcceptChangesDuringFill和
AcceptChangesDuringUpdate,这个属性默认值为true,就实现了上面所说的自动调用

5.DataSet.GetChange/DataTable.GetChange,DataSet.Merge/DataTable.Merge,DataTable.Select方法
GetChange()能从数据集中选择出与数据集初始状态发生了变化的数据行,返回一个数据子集,是跟据DataViewRowState来进行判断的
Merge()能将数据集合并,如果对象是DataTable/DataRow[],默认合并进DataSet.Table[0],如果对象是DataSet,则第0个合并进第0个,第1个合并进第1个,以此类推,它是跟据主键来判断与合并的
有个比较好的文章:
http://www.chinaitpower.com/A/2004-11-09/136465.html

Select()能从数据集中选择出特定的数据子集,结果是DataRow[],括号内参数与sql的where子句写法一样,如:DataTable.Select("id>5")

两篇比较好的文章:
http://blog.csdn.net/zhzuo/archive/2005/01/03/238273.aspx
http://blog.csdn.net/zhzuo/archive/2004/08/06/67037.aspx
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值