解决同时修改同一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
测试结果.这个计数值是全库唯一的,只要对库内的记录进行增/改操作,此计数器就会++.
用户在修改记录时先取出计数器值.保存时再对出此记录的计数器做对比,就知道是否有其他用户已经修改过.就可以通知用户是覆盖记录还是合并记录.. :-)
微软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
测试结果.这个计数值是全库唯一的,只要对库内的记录进行增/改操作,此计数器就会++.
用户在修改记录时先取出计数器值.保存时再对出此记录的计数器做对比,就知道是否有其他用户已经修改过.就可以通知用户是覆盖记录还是合并记录.. :-)
相关文章推荐
- 如何解决p6spy日志记录sql语句重复的问题
- MySQL游标修改记录——解决最后一行重复的问题
- 解决 log4j:ERROR Failed to rename,不需要修改源码。同时解决工程重复加载的问题。
- 不修改SQL_Latin1_General_CP1_CI_AS 字符集 解决中文条件查询问题
- 使用PL/SQL Developer连接远程oracle客户端报错问题解决记录
- 解决并发时 “回显修改” 同时修改时,后面的修改会覆盖前面的问题。
- [SQL] SQLServer修改DB的collation, 解决排序字规则字符集问题
- Access转成Sql 2008步骤,同时解决自动编号问题,主键,id数值不重置
- java.sql.SQLException: 关闭的连接问题及hibernate clob缓冲流存储的解决过程记录
- 【django】解决migrations没有修改表的问题记录
- CenOS下mysql5.6修改字符编码,解决sql语句中带有中文,会乱码问题
- 解决计算机名修改或作业移植导致的服务器名问题.sql
- mysql导入导出数据中文乱码解决方法小结(1、navicat导入问题已解决,创建连接后修改连接属性,选择高级->将使用Mysql字符集复选框去掉,下拉框选择GBK->导入sql文件OK;2、phpmyadmin显示乱码的问题也解决,两步:1.将sql文件以utf8的字符集编码另存,2.将文件中sql语句中的字段字符集编码改成utf8,导入OK)
- 多人同时修改同一订单问题
- Redis:解决分布式高并发修改同一个Key的问题
- 如何使用 BindingSource 绑定 ListBox,同时解决绑定 List<T> 后修改数据源不能同时刷新界面显示的问题
- 解决oracle sqlplus 不能修改,退格问题
- Access转成Sql 2008步骤,同时解决自动编号问题,主键,id数值不重置。
- 关于tomcat端口的修改,以及同时部署多个应用,自己遇到的问题以及解决办法
- Oracle多用户同时修改同一记录,怎样保证该客户记录