WEB开发网
开发学院数据库MSSQL Server 小议SQL Server主键和自动编号问题 阅读

小议SQL Server主键和自动编号问题

 2009-05-16 10:28:16 来源:WEB开发网   
核心提示: 听棠.NET指出:主档放在事务中提交时,通过@@IDENTITY 就可以取到生成值的,小议SQL Server主键和自动编号问题(2),因此可以传给明细当外键用,而且在事务发生错误回滚时,这样存在级联关系的两张表更新时,一张表更新后另外一张表对应键的值也会自动发生变化,主档记录也会被回滚取

听棠.NET指出:主档放在事务中提交时,通过@@IDENTITY 就可以取到生成值的,因此可以传给明细当外键用,而且在事务发生错误回滚时,主档记录也会被回滚取消的。

吕震宇补充:使用自动增长字段会增加网络的roundTrip。尽管可以使用@@IDENTITY取得主键的值,但在更新过程中,不得不增加一次数据往返(以C/S结构为例):

1、客户端发送开始事务命令

2、客户端提交主表更新

3、服务器返回@@IDENTITY

4、客户端根据返回的主键更新从表缓冲

5、客户端将从表提交服务器更新

6、客户端提交事务

在这里多了一次往返就会增加了事务处理的时间。降低并发性能。

如果不用自动增长型字段,将是以下情景:

1、客户端发送开始事务命令

2、客户端提交主表更新

3、客户端提交从表更新

4、客户端提交事务

因此我不赞成使用自动增长型字段作为主键与外键链接的纽带。

除此之外,当我们需要在多个数据库间进行数据的复制时(SQL Server的数据分发、订阅机制允许我们进行库间的数据复制操作),自动增长型字段可能造成数据合并时的主键冲突。设想一个数据库中的Order表向另一个库中的Order表复制数据库时,OrderID到底该不该自动增长呢?

ADO.NET允许我们在 DataSet中将某一个字段设置为自动增长型字段,但千万记住,这个自动增长字段仅仅是个占位符而已,当数据库进行更新时,数据库生成的值会自动取代 ADO.NET分配的值。所以为了防止用户产生误解,建议大家将ADO.NET中的自动增长初始值以及增量都设置成-1。此外,在ADO.NET中,我们可以为两张表建立DataRelation,这样存在级联关系的两张表更新时,一张表更新后另外一张表对应键的值也会自动发生变化,这会大大减少了我们对存在级联关系的两表间更新时自动增长型字段带来的麻烦。

上一页  1 2 3 4 5  下一页

Tags:小议 SQL Server

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接