一般是这样的,如果用设计器将SqlDataAdapter拖到页面中使用时,不会出现SqlDataAdapter.Update(ds)更新时出错情况,因为系统会自动生成SqlDataAdapter的属性命令,比如: .UpdateCommane insertCommand selectCommand等。  但是有些程序员不喜欢用设计器,或者是有些地方没必要拖动SqlDataAdapter这么个庞大物来实现,那么SqlDataAdapter就不会自动生成相关的查询或更新语句了。 所以当执行到SqlDataAdapter.Update(ds)语句时,SqlDataAdapter桥接器不知道更新哪个表不报错了。
解决方法:用SqlCommandBuilder 实现批量更新
1.功能:
可以实现你对DataSet在UI层做任意操作后,直接丢给这个方法,这个方法就可以自动把你的修改更 新到数 据库中,而没必要每次都更新到数据库
2.使用方法

 public int UpdateByDataSet(DataSet ds,string strTblName,string strConnection)
 {
  try
 {
  SqlConnection conn = new SqlConnection(strConnection));
  SqlDataAdapter myAdapter = new SqlDataAdapter();
  SqlCommand myCommand = new SqlCommand("select * from "+strTblName),(SqlConnection)this.conn);  
  myAdapter.SelectCommand = myCommand;
  SqlCommandBuilder myCommandBuilder = new SqlCommandBuilder(myAdapter);  
  myAdapter.Update(ds,strTblName); 
  return 0;
}
catch(BusinessException errBU)
{ 
  throw errBU;
} 
catch(Exception err)
{ 
  throw new BusinessException(err);
}
}

直接调用这个方法就可以啦,说明的一点是select * from "+strTblName是一定要的,作用大家也应该想到了,主要是告诉SqlDataAdapter更新哪个表。
3.什么时候用"color: #ff0000">4.注意点:
   1).只能更新一个表,不能更新两个或两个以上相关联的表
   2).表中必须有主键
   3).更新的表中字段不能有image类型的
5.优点:
    节省代码量,节省时间,这个方法可以代替所有的:  更新/删除/插入操作语句
6.缺点:
    访问两次数据库(select * TableName,就是这句,要确认是哪个表,除非是很大的数据量, 一般是感觉不到的),效率有些慢。

以上就是用SqlCommandBuilder 实现批量更新的方法,介绍了其优缺点,以及注意点,内容很详细,希望大家可以喜欢。

标签:
SqlCommandBuilder,批量,更新

免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
狼山资源网 Copyright www.pvsay.com

评论“SqlCommandBuilder如何实现批量更新”

暂无“SqlCommandBuilder如何实现批量更新”评论...