您的位置:首页 > 数据库

解决同时修改同一SQL记录的问题

2008-06-25 21:56 411 查看
在寻找PowerDesigner相关信息的时候偶然发现的.使用timestamp

微软MSDN内容:

timestamp (Transact-SQL)

公开数据库中自动生成的唯一二进制数字的数据类型。timestamp 通常用作给表行加版本戳的机制。 存储大小为 8 个字节。 timestamp 数据类型只是递增的数字,不保留日期或时间。 若要记录日期或时间,请使用 datetime 数据类型。


备注

每个数据库都有一个计数器,当对数据库中包含 timestamp 列的表执行插入或更新操作时,该计数器值就会增加。 该计数器是数据库时间戳。 这可以跟踪数据库内的相对时间,而不是时钟相关联的实际时间。 一个表只能有一个 timestamp 列。 每次修改或插入包含 timestamp 列的行时,就会在 timestamp 列中插入增量数据库时间戳值。 这一属性使 timestamp 列不适合作为键使用,尤其是不能作为主键使用。 对行的任何更新都会更改 timestamp 值,从而更改键值。 如果该列属于主键,那么旧的键值将无效,进而引用该旧值的外键也将不再有效。 如果该表在动态游标中引用,则所有更新均会更改游标中行的位置。 如果该列属于索引键,则对数据行的所有更新还将导致索引更新。

使用某一行中的 timestamp 列可以很容易地确定该行中的任何值自上次读取以后是否发生了更改。 如果对行进行了更改,就会更新该时间戳值。 如果没有对行进行更改,则该时间戳值将与以前读取该行时的时间戳值一致。 若要返回数据库的当前时间戳值,请使用 http://msdn.microsoft.com/zh-cn/library/ms187366.aspx

Transact-SQL timestamp 数据类型不同于在 SQL-2003 标准中定义的 timestamp 数据类型。 SQL-2003 timestamp 数据类型等同于 Transact-SQL datetime 数据类型。

我的测试结果:

--建立一个Table

create table tmp1

(

name varchar(20),

timestamp

)

go

--插入记录

insert into tmp1 values('tony',null)

select * from tmp1

go

--执行结果(因为之前已经有插入过了.所以是D):tony 0x000000000000300D

--修改记录

update tmp1 set name='tonywu'

select * from tmp1

go

--执行结果:tonywu 0x000000000000300E

update tmp1 set name='tony wu'

select * from tmp1

go

--执行结果:tony wu 0x000000000000300F

--再插入一笔

insert into tmp1 values('wgj',null)

select * from tmp1

--执行结果:

--tony wu 0x000000000000300F

--wgj 0x0000000000003010

update tmp1 set name='w g j' where name='wgj'

select * from tmp1

--执行结果:

--tony wu 0x000000000000300F

--w g j 0x0000000000003012

update tmp1 set name='Tony Wu' where name='tony wu'

select * from tmp1

--执行结果:

--Tony Wu 0x0000000000003013

--w g j 0x0000000000003012

--再建另一个表

create table tmp2

(

no varchar(20),

timestamp

)

go

insert into tmp2 values('AB001',null)

go

select * from tmp2

--执行结果:

--AB001 0x0000000000003014

--得到这个数据库的当前的计数值

select @@DBTS

--执行结果:0x0000000000003014

--测试删除会不会影响计数值

delete from tmp

select @@DBTS

--执行结果:0x0000000000003014

测试结果.这个计数值是全库唯一的,只要对库内的记录进行增/改操作,此计数器就会++.

用户在修改记录时先取出计数器值.保存时再对出此记录的计数器做对比,就知道是否有其他用户已经修改过.就可以通知用户是覆盖记录还是合并记录.. :-)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐