经典ADO.NET DataSet技巧总结

开发 后端
这里就ADO.NET DataSet方法技巧避免自动增量值冲突、检查开放式并发冲突、多线程编程三个方面做出总结,大家仔细阅读会从中得到不少的收获。

ADO.NET是多种访问数据库技术中我最喜欢用的,下面我们就一些编写 ADO.NET 代码时的通用技巧介绍一下吧,希望大家能记住留着以后编程中使用。

避免自动增量值冲突

就像大多数数据源一样,ADO.NET DataSet使您可标识那些添加新行时自动对其值进行递增的列。在 DataSet 中使用自动增量的列时,如果自动增量的列来自数据源,可避免添加到 DataSet 的行和添加到数据源的行之间本地编号冲突。

#T#例如,考虑一个表,它的主键列 CustomerID 是自动增量的。两个新的客户信息行添加到表中,并接收到自动增量的 CustomerID 值 1 和 2。然后,只有第二个客户行被传递给 DataAdapter 的方法 Update,新添加的行在数据源接收到一个自动增量的 CustomerID 值 1,与 DataSet 中的值 2 不匹配。当 DataAdapter 用返回值填充表中第二行时,就会出现约束冲突,因为***个客户行已经使用了 CustomerID 值 1。

要避免这种情况,建议在使用数据源上自动增量的列以及 ADO.NET DataSet 上自动增量的列时,把 DataSet 中的列创建为 AutoIncrementStep 值等于 -1 并且 AutoIncrementSeed 值等于 0,另外,还要确保数据源生成的自动增量标识值从 1 开始,并且以正阶值递增。因此,DataSet 为自动增量值生成负数,与数据源生成的正自动增量值不冲突。另外一个选择是使用 Guid 类型的列,而不是自动增量的列。生成 Guid 值的算法应该永远不会使数据源中生成的 Guid 值与 DataSet 中生成的 Guid 值一样。如果自动增量的列只是用作唯一值,而且没有任何意义,就考虑使用 Guid 代替自动增量的列。它们是唯一的,并且避免了使用自动增量的列所必需的额外工作。

检查开放式并发冲突

按照设计,由于 DataSet 是与数据源断开的,所以,当多个客户端在数据源上按照开放式并发模型更新数据时,需要确保应用程序避免冲突。在测试开放式并发冲突时有几项技术。一项技术涉及在表中包含时间戳列。另外一项技术是,验证一行中所有列的原始值是否仍然与通过在 SQL 语句中使用 WHERE 子句进行测试时在数据库中找到的值相匹配。

多线程编程

ADO.NET 对性能、吞吐量和可伸缩性进行优化。因此,ADO.NET 对象不锁定资源,并且必须只用于单线程。一个例外是ADO.NET DataSet,它对多个阅读器是线程安全的。但是,在写的时候需要把 DataSet 锁定。仅在需要的时候才用 COM Interop 访问 ADO

ADO.NET 的设计目的是成为许多应用程序的***解决方案。但是,有些应用程序需要只有使用 ADO 对象才有的功能,例如,ADO 多维 (ADOMD)。在这些情况下,应用程序可以用 COM Interop 访问 ADO。注意使用 COM Interop 访问具有 ADO 的数据会导致性能降低。在设计应用程序时,首先在实现用 COM Interop 访问 ADO 的设计之前,先确定 ADO.NET 是否满足设计需求。

责任编辑:田树 来源: 博客
相关推荐

2009-10-29 10:44:18

ADO.NET Dat

2009-10-29 11:08:20

ADO.NET Dat

2009-11-04 11:40:38

ADO.NET Dat

2009-11-13 09:24:17

2009-10-29 08:51:24

ADO.NET结构

2009-11-03 17:25:59

ADO.NET编程技巧

2009-10-29 13:34:01

ADO.NET对象

2009-11-11 14:27:32

ADO.NET函数

2009-10-29 10:34:31

ADO.NET使用技巧

2009-12-22 16:35:11

ADO.NET控件

2009-12-21 13:19:34

ADO.NET组件

2009-12-22 09:50:23

ADO.NET学习

2009-12-21 15:58:19

ADO.NET集合

2010-05-24 09:49:47

ADO.NET

2009-12-29 14:55:31

ADO.NET Dat

2009-12-28 15:46:22

ADO.NET操作

2009-12-21 13:59:03

ADO.NET特性

2009-12-21 14:39:09

ADO.NET技巧

2009-11-12 12:39:16

ADO.NET Sta

2009-12-25 16:26:03

ADO.NET控制
点赞
收藏

51CTO技术栈公众号