• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >ASP.NET > SqlCommandBuilder如何实现批量更新

SqlCommandBuilder如何实现批量更新

作者:tracywang 字体:[增加 减小] 来源:互联网 时间:2017-05-11

tracywang通过本文主要向大家介绍了sqlcommandbuilder,c sqlcommandbuilder,如何实现页面局部更新,主页内容更新如何实现,安卓实现版本更新等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

一般是这样的,如果用设计器将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);
}
}
</div>

直接调用这个方法就可以啦,说明的一点是select * from "+strTblName是一定要的,作用大家也应该想到了,主要是告诉SqlDataAdapter更新哪个表。
3.什么时候用?
    a. 有时候需要缓存的时候,比如说在一个商品选择界面,选择好商品,并且进行编辑/删除/更新后,
       最后一并交给数据库,而不是每一步操作都访问数据库,因为客户选择商品可能进行n次编辑/删除
       更新操作,如果每次都提交,不但容易引起数据库冲突,引发错误,而且当数据量很大时在用户执行
       效率上也变得有些慢
    b.有的界面是这样的有的界面是这样的,需求要求一定用缓存实现,确认之前的操作不提交到库,点击
      页面专门提交的按钮时才提交商品选择信息和商品的其它信息. 我经常遇到这样的情况
    c.有些情况下只往数据库里更新,不读取. 也就是说没有从数据库里读,SqlDataAdapter也就不知道是
      更新哪张表了,调用Update就很可能出错了。这样的情况下可以用SqlCommandBuilder 了.
4.注意点:
   1).只能更新一个表,不能更新两个或两个以上相关联的表
   2).表中必须有主键
   3).更新的表中字段不能有image类型的
5.优点:
    节省代码量,节省时间,这个方法可以代替所有的:  更新/删除/插入操作语句
6.缺点:
    访问两次数据库(select * TableName,就是这句,要确认是哪个表,除非是很大的数据量, 一般是感觉不到的),效率有些慢。

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

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • SqlCommandBuilder类批量更新excel或者CSV数据的方法
  • SqlCommandBuilder如何实现批量更新

相关文章

  • 2017-05-11详细介绍.NET中的动态编译技术
  • 2017-05-11如何解决Ajax请求结果的缓存问题说明
  • 2018-08-20.Net Core内存回收模式及性能测试对比分析
  • 2017-05-11ASP.NET笔记之 图库权限设置的方法
  • 2017-05-11ASP.NET中为DataGrid添加合计字段
  • 2017-05-11ASP.NET Gridview与checkbox全选、全不选实现代码
  • 2017-05-11asp.net cookie清除的代码
  • 2017-05-11C# FTP,GetResponse(),远程服务器返回错误
  • 2017-05-11ASP.NET中利用DataList实现图片无缝滚动 实例分享
  • 2017-05-11ASP.NET中实现根据匿名类、datatable、sql生成实体类

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • ASP.NET 用户控件的使用介绍
    • 加密web.config的方法分享
    • asp.net Repeater取得CheckBox选中的某行某个值的c#写法
    • asp.net Gridview行绑定事件新体会
    • 手把手教你在.NET中创建Web服务实现方法
    • 提交页面的定位--scrollIntoView的用法
    • asp.net利用母版制作页脚效果
    • asp.net基于windows服务实现定时发送邮件的方法
    • jQuery实现倒计时跳转的例子
    • .NET Core如何获取操作系统中的各种信息

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有