首 页 网络编程
网页制作 图形图象 操作系统 冲浪宝典
软件教学 认证考试

网络安全 网络办公 行业资讯 评测对比
您当前位置:站长天空 -> 网络编程-> Visual Basic教程
.NET下使用DataAdapter保存数据时,如何生成command语句及使用事务-.NET教程,数据库应用
作者:网友供稿 点击:196
推荐
西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!可在线rar解压,自动数据恢复设置虚拟目录等.免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金
站内搜索
文章页数:[1] 

在.net下,运用dataset对数据进行批量更新时,需要与 dataadapter配合使用。dataadapter数据适配器的作用是生成数据更新时所需的insert,delete,update等语句,这些语句一般在开发阶段,在ide环境下生成,但是如果需要在程序中动态配置数据来源,那么dataadapter的insert,delete,update语句就需要动态生成了。这就是sqlcommandbuilder 对像了(以sqldataadapter对像为例,如果是别的dataadapter对像,则可改为dbcommandbuilder )。例如有以下更新方法

        /// <summary>
        /// 根据传入的sql语句,为dataadapter动态生成command语句,并将数据保存到数据库
        /// </summary>
        /// <param name="ds">需操作的dataset</param>
        /// <param name="connectstr">数据库连接字符串</param>
        /// <param name="tablename">dataset中的指定需更新的表</param>
        /// <param name="sqlstr">数据来源sql语句,需要有主键才能更新</param>

        public void datasetupdate(dataset ds,string connectstr,string tablename,string sqlstr)
        {
           try
            {
                sqldataadapter adapter = new sqldataadapter(sqlstr, connectstr);   

                //使用sqlcommandbuilder  对像填充sqldataadapter 的insertcommand、deletecommand、updatecommand对像
                sqlcommandbuilder cmdbuilder = new sqlcommandbuilder(adapter);


                int val = adapter.update(ds, tablename);
                ds.acceptchanges();
            }
            catch
            {
                throw;
            }
        }

以上完成对单个数据表的保存,如果需要将多个数据表保存到数据库,就需要运用事务,将以上方法重载一次

        public void datasetupdate(dataset ds, sqlconnection sqlconnect, string tablename, string sqlstr,sqltransaction sqltrans)
        {
            try
            {
                sqldataadapter adapter = new sqldataadapter(sqlstr, sqlconnect);


                sqlcommandbuilder cmdbuilder = new sqlcommandbuilder(adapter);

               //创建sqldataadapter 对像的command对像,并将连接对像及事务对像绑定到command对像上

                adapter.deletecommand = new sqlcommand("", sqlconnect, sqltrans);
                adapter.insertcommand = new sqlcommand("", sqlconnect, sqltrans);
                adapter.updatecommand = new sqlcommand("", sqlconnect, sqltrans);
                adapter.selectcommand = new sqlcommand(sqlstr, sqlconnect, sqltrans);

               //使用getdeletecommand将相对应的sqlcommand对像传入

                adapter.deletecommand = cmdbuilder.getdeletecommand();
                adapter.insertcommand = cmdbuilder.getinsertcommand();
                adapter.updatecommand = cmdbuilder.getupdatecommand();
                //cmdbuilder.refreshschema();
                int val = adapter.update(ds, tablename);
                ds.tables[tablename].acceptchanges();
            }
            catch
            {
                throw;
            }
        }

通过以上方法,将sqldataadapter 对像的更新绑定到了事务,那么在外层调用如下

            system.data.sqlclient.sqlconnection sqlcon = new system.data.sqlclient.sqlconnection(connectionstring);
            system.data.sqlclient.sqltransaction sqltran;
            sqlcon.open();

            //将事务绑定到连接对像
            sqltran = sqlcon.begintransaction();
            try
            {
                db.datasetupdate(ds, sqlcon, "main", "select lx as id,mc,xgrq from ddjgfl ",sqltran);
                db.datasetupdate(ds, sqlcon, "ciled", "select ddbh,ksbh,ksmc,lsbm,mzbz,zybz,yjbz,czksbz,ykbz from ksdj", sqltran);
                sqltran.commit();
            }
            catch(system.data.sqlclient.sqlexception sqlex)
            {
                sqltran.rollback();
                messagebox.show(sqlex.message);
            }
            catch (exception ex)
            {
                sqltran.rollback();
                messagebox.show(ex.message);
            }
            finally
            {
            }


文章整理:站长天空 网址:http://www.z6688.com/
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

文章页数:[1] 


放大字体显示 缩小字体显示 打印文章 推荐给朋友
热门文章
·ASP.net中动态加载控件时一些问题的总结-ASP教程,ASP应用
·C#读写注册表-.NET教程,C#语言
·Visual Basic .NET中的异常处理简介(下)-.NET教程,VB.Net语言
·C#:文件的按行读/写及文件目录对话框的使用-.NET教程,C#语言
·ADO.Net:使用DataReader向数据库中插入数据-ASP教程,数据库相关
·列一张网恋赔偿清单(爆笑)
·如何用Photoshop画服装款式图-网页设计,Photoshop
·.NET下使用DataAdapter保存数据时,如何生成command语句及使用事务-.NET教程,数据库应用
·新型dc/dc电源控制芯片dpa426的应用
·ASP.NET 2.0 - Enter Key - Default Submit Button-.NET教程,Asp.Net开发
最新文章
·个人站长的网络赚钱两条新出路_网赚技巧
·adsense帐户最佳化纵深谈-adsense资深专员_网赚技巧
·google adsense容易被k的可能性列表_网赚技巧
·如何让程序被站长接受和产生利润_站长访谈
·马云,即成的中国互联网第4代霸主_站长访谈
·google关键词广告创建的十二招_google推广
·如何使google更快速收录你的新站_google推广
·几个颇有创意的网站推广方法_站长心得
·网络编辑:标题,如何让网民一见钟情(2)_网络编辑
·网站建设基础seo搜索引擎优化_seo网站优化
相关主题
  • .net下几种日志管理方法_asp.net技巧
  • .net下访问access数据库需要注意的问题_asp.net技巧
  • .net下生产图片验证码_asp.net技巧
  • .net下正则表达式应用的四个示例_asp.net技巧
  • .Net下几种日志管理方法-.NET教程,.NET Framework
  • 西部数码虚拟主机

    友情链接
    CNNIC 西部数码
    万网 自助建站
    虚拟主机 asp空间
    域名注册 域名
    域名申请 主页空间
    论坛空间 网站空间
    国际域名 虚拟空间
    空间租用 DDOS防火墙
    成都主机托管 四川主机托管
    主机租用 服务器租用
    网站目录 自助建站
    虚拟主机 网址大全
    软件下载
    自助链接
    虚拟主机资讯 特价虚拟主机
    版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!
    关于我们:站长天空:专业提供最新的站长资讯、在线教程、虚拟主机权威评测、虚拟主机性能对比、网站制作教程,开发教程,站长工具。包括网页制作教程、冲浪宝典、编程参考、操作系统、软件教学、行业动态等。
    特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
    发表评论 打印  刷新     关闭