ado.net数据同步

ado.net有两种数据访问策略:  
   
  直接对数据库操作(command)和使用离线数据集(dataset)  
   
  前者直接对数据库读写(增加,删除,修改),后者虽然在内存中,但是可以  
   
  通过绑定实现数据同步,DataAdapter是dataset和database的桥梁 

 

这里给出两个例子,例1使用Command修改数据库,例2使用DataAdapter和DataSet.  
   
  例1:  
  SqlConnection   cn   =   new   SqlConnection("server=ServerName;database=Northwind;uid=sa;pwd=sa");  
  SqlCommand   cmd   =   new   SqlCommand("Update   TableName   set   FieldName   =   xxx   where   FieldName   =   x",cn);  
  cn.Open();  
  cmd.ExecuteNonQuery();  
  cn.Close();  
   
  例2:  
  SqlConnection   cn   =   new   SqlConnection("server=ServerName;database=Northwind;uid=sa;pwd=sa");  
  DataSet   ds   =   new   DataSet();  
  SqlCommand   cmd   =   new   SqlCommand("select   *   from   TableName   order   by   FieldName",   cn);  
  SqlDataAdapter   da   =   new   SqlDataAdapter(cmd);  
  SqlCommandBuilder   cmb   =   new   SqlCommandBuilder(da)  
   
  da.Fill(ds,   "TableName");  
  ds.Tables[0].Rows[0]["FieldName"]   =   xxx;  
  da.Update(ds,   "TableName");          
   
  另外,如果你已经打开一个DataSet一段时间,想重新从数据库中提取数据以保持同步,可以把DataSet清空(Clear),再Fill一次:  
  ds.Clear();  
  da.Fill(ds,"TableName");  
   
  希望以上对你有所帮助。  
   
  -   微软全球技术中心  
   
  本贴子以“现状”提供且没有任何担保,同时也没有授予任何权利。具体事项可参见使用条款  
  (http://support.microsoft.com/directory/worldwide/zh-cn/community/terms_chs.asp)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值