知识大全 当DataSet中包含主/子表时,Update更新步骤

Posted 规则

篇首语:宿命论是那些缺乏意志力的弱者的借口。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 当DataSet中包含主/子表时,Update更新步骤相关的知识,希望对你有一定的参考价值。

当DataSet中包含主/子表时,Update更新步骤  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!

  (一) 序幕

  当DataSet中同时包含主/子表(主键表/外键表)时 有时候关系约束太严格 比如 关系数据库完整性规则 实体完整性 主键表中主键不准为空

   参照完整性 外键表中外键的值必须与主键表中的主键对应

  要么为空 要么为主键表中的一主键值

   自定义完整性

  如果DataSet表中定义的多表关系约束太严密 直接用Update方法将DataSet中多表一起提交时 有可能不满足完整性规则 会发生错误 原因 举个例子 设为两个表 CompanyMain(公司主表)和CompanySon(公司子表)

  CompanyMain(公司主表)主要存储一个公司的基本信息 CompanySon(公司子表)

  主要存储此公司的一些客户的信息 并且公司主表中的(ID)与子表中的(BelongID)

  建立关联 即主外键关系 一个公司对应着多个客户 即ID BelongID = n关系

  主表的ID为自动生成编号

  那么 在新增公司界面 一起提交时 系统是不会遵守 数据库完整性规则 来更新到数据库的

  如果它先更新子表 再更新主表有可能就会报错 原因是主表的公司信息还没有插入到数据库中的表 也就没有生成公司编号 ID 则子表更新时就会没有对应的BelongID 这时如果设置了 外键表中的外键不为null 完整性规则 就会引发异常

  这只是一种出错的可能 还有更多的出错可能性 在分布式设计中更容易出现这样的错误

  (二) 解决办法

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

   规则 在DataSet更新之前按 <表> 和 <表的RowState属性>进行拆分提交

  I 按 <表> 进行拆分提交意思是说

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

  II 按 <表的RowState属性>进行拆分提交意思是说

  对DataSet中的单个表根据RowState属性 再进行拆分 对RowState

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

   规则

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

  即 先更新DataRowState 值为 Added和Modified的 再更新 Deleted的

   规则

  在规则 和规则 基础上 如果DataRowState为Added和Modified 则先更新主表 后更新子表

  在规则 和规则 基础上 如果DataRowState为Deleted 则先更新子表 后更新主表

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

   将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) //取得主表中删除的

  行记录集

   更新主表DataRowState状态为 Added和Modified的记录

  SqlDataAdapter Update(dsAdded dtCompanyMain ) //更新添加的记录集到数据库

  SqlDataAdapter Update(dsModified dtCompanyMain ) //更新修改的记录集到数据

  库

   更新子表DataRowState状态为 Added和Modified的记录

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

   更新子表DataRowState状态为 Deleted的记录

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

   更新主表DataRowState状态为 Deleted的记录

cha138/Article/program/net/201311/12582

相关参考

知识大全 用数据适配器来填充 DataSet

C#高级编程:用数据适配器来填充DataSet  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!&nb

知识大全 深入分析ADO.NET中的DataSet对象

深入分析ADO.NET中的DataSet对象  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  AD

知识大全 C#中将DataSet的内容写成XML

C#中将DataSet的内容写成XML  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  许多读者经

知识大全 JAVA处理含有DataSet的web services

JAVA处理含有DataSet的webservices  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧

知识大全 简便的将DataSet导入到数据库中

简便的将DataSet导入到数据库中  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  有时候我们需

知识大全 ADO.NET 2.0中的DataSet和DataTable

ADO.NET2.0中的DataSet和DataTable  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一

知识大全 ASP.NET中DataTable与DataSet之间的转换

ASP.NET中DataTable与DataSet之间的转换  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看

知识大全 asp.net水晶报表中实现关联主表和子表

  一使用视图meeting将多表关联整合在一起  二通过Sql语句筛选数据  三建立和主从表的关联  四注意在CrystalReport表中插入子报表的时候一定要将主从表的关联字段设置好否则出乱子 

知识大全 ADO.NET 2.0 Dataset和Datatable 新功能新

ADO.NET2.0Dataset和Datatable新功能新  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来

知识大全 Linq to DataSet 之Access查询

LinqtoDataSet之Access查询  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!Linq