分享
 
 
 

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

王朝other·作者佚名  2006-01-10
窄屏简体版  字體: |||超大  

(一) 序幕

当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"); //更新修改的记录集到数据库

谢谢阅读!

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有