欢迎光临
我们一直在努力

当DataSet中包含主/子表时,Update更新步骤-.NET教程,评论及其它

建站超值云服务器,限时71元/月

 

(一) 序幕

当dataset中同时包含主/子表(主键表/外键表)时,有时候关系约束太严格:
   比如, 关系数据库完整性规则:
      1.实体完整性. 主键表中主键不准为空.  
      2.参照完整性. 外键表中外键的值必须与主键表中的主键对应. 
         要么为空,要么为主键表中的一主键值.
      3.自定义完整性.   
  如果dataset表中定义的多表关系约束太严密,直接用update方法
  将dataset中多表一起提交时,有可能不满足完整性规则,会发生错误,
    原因: 举个例子,设为两个表: companymain(公司主表)和companyson(公司子表)
   companymain(公司主表)主要存储一个公司的基本信息,companyson(公司子表)
   主要存储此公司的一些客户的信息. 并且公司主表中的(id)与子表中的(belongid)
   建立关联,即主外键关系; 一个公司对应着多个客户,即id:belongid = 1 : n关系.
   主表的id为自动生成编号.
   那么:
   在新增公司界面,一起提交时,系统是不会遵守”数据库完整性规则”来更新到数据库的.
   如果它先更新子表,再更新主表有可能就会报错.  原因是主表的公司信息还没有插入
  到数据库中的表,也就没有生成公司编号: id,则子表更新时就会没有对应的belongid.
   这时如果设置了: “外键表中的外键不为null”完整性规则,就会引发异常.
   这只是一种出错的可能,还有更多的出错可能性,在分布式设计中更容易出现这样的错误.

(二). 解决办法

   一般遵守以下几条规则,就会避免大量的出错机率.

   1规则.   在dataset更新之前按 <表> 和 <表的rowstate属性>进行拆分提交

          i.  按 <表> 进行拆分提交意思是说:

                         对dataset 中的表不是一起提交,而是一次提交一个表,进行多次提交

          ii.按 <表的rowstate属性>进行拆分提交意思是说:

                       对dataset中的单个表根据rowstate属性,再进行拆分,对rowstate

                       相同的进行一次提交,也是提交多次

   2.规则.      

       在规则1基础上, 先更新状态为<新增> 和 <修改> 的,再更新<删除的>

       即: 先更新datarowstate 值为: added和modified的,再更新: deleted的.

  3.规则

       在规则1和规则2基础上,如果datarowstate为added和modified,则先更新主表,后更新子表.

       在规则1和规则2基础上,如果datarowstate为deleted,则先更新子表,后更新主表.

(三) 归纳一下上面三条规则,如下:

        1.将dataset中的表拆分,并根据rowstate将各个表记录进行分组并存储在不同的数据集中

            //这里要存储在dataset中,是因为: update接受的是dataset的参数,还有webservice只支持

            //dataset,对其进行序列化操作

              代码示例:

                     设待更新的数据集为: dscompany(里面包括两个表,分别为主表和子表,并存储了

数据,待更新)

           

             //dtcompanymain存储公司主表信息,dtcompanyson存储公司子表信息

             datatable dtcompanymail = ds.tables[“dtcompanymain”].clone();  //分离出主表数据

并存储另一对象

             datatable dtcompanyson  = ds.talbes[“dtcompanyson”].clone();  //分离出子表数据

并存储另一对象

             dataset dsadded = new dataset();            //存放主表 新增 的数据

             dataset dsmidified = new dataset();          //存储主表  编辑 的行记录

             dataset dsdeleted = new dataset();         //存储主表 删除 的行记录

              dsadded = dtcompanymain.getchanges(datarowstate.added);   //取得主表中新增的行

记录集

              dsmidified = dtcompanymain.getchanges(datarowstate.modified);  //取得主表中编

辑的行记录集

             dsdeleted = dtcompanymain.getchanges(datarowstate.deleted);  //取得主表中删除的

行记录集             

        2.更新主表datarowstate状态为: added和modified的记录.

              sqldataadapter.update(dsadded,”dtcompanymain”);   //更新添加的记录集到数据库

              sqldataadapter.update(dsmodified,”dtcompanymain”);   //更新修改的记录集到数据

        3.更新子表datarowstate状态为: added和modified的记录

               ………….  //代码省略,跟2主表更新类似

        4.更新子表datarowstate状态为: deleted的记录.

              …………   // 代码省略,与下面5类似

        5.更新主表datarowstate状态为: deleted的记录

            sqldataadapter.update(dsdeleted,”dtcompanymain”);   //更新修改的记录集到数据库

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » 当DataSet中包含主/子表时,Update更新步骤-.NET教程,评论及其它
分享到: 更多 (0)