您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息
免费发信息
三六零分类信息网 > 拉萨分类信息网,免费分类信息发布

关于timestamp的二三事_MySQL

2024/3/16 4:15:42发布45次查看
之所以要写timestamp的随笔,是因为之前对它的理解存在误区,so. i have to remind myself by writing this informal essay.
微软文档链接:https://msdn.microsoft.com/zh-cn/library/ms182776.aspx
释义(rowversion和timestamp是一样的好比c#里的(string和string是一个概念 同义词,写法不一样而已 ),不过微软好像建议用 rowversion ,数据库上操作还是有差别的暂时未深入研究,可查询下面的超链接看看):
公开数据库中自动生成的唯一二进制数字的数据类型。 rowversion 通常用作给表行加版本戳的机制。 存储大小为 8 个字节。 rowversion 数据类型只是递增的数字,不保留日期或时间。 若要记录日期或时间,请使用 datetime2 数据类型。
注释
每个数据库都有一个计数器,当对数据库中包含 rowversion 列的表执行插入或更新操作时,该计数器值就会增加。 此计数器是数据库行版本。 这可以跟踪数据库内的相对时间,而不是时钟相关联的实际时间。 一个表只能有一个 rowversion 列。 每次修改或插入包含 rowversion 列的行时,就会在 rowversion 列中插入经过增量的数据库行版本值。 这一属性使 rowversion 列不适合作为键使用,尤其是不能作为主键使用。 对行的任何更新都会更改行版本值,从而更改键值。 如果该列属于主键,那么旧的键值将无效,进而引用该旧值的外键也将不再有效。 如果该表在动态游标中引用,则所有更新均会更改游标中行的位置。 如果该列属于索引键,则对数据行的所有更新还将导致索引更新。
timestamp 的数据类型为 rowversion 数据类型的同义词,并具有数据类型同义词的行为。 在 ddl 语句,请尽量使用 rowversion 而不是 timestamp。 有关详细信息,请参阅数据类型同义词 (transact-sql)。
transact-sql timestamp 数据类型不同于在 iso 标准中定义的 timestamp 数据类型。
从上面释义才醒悟,时间戳 和日期、时间半毛钱关系都没有。 只是个二进制值。哎....  timestamp  大家基本都知道用于并发控制的,但怎么实现 怎么操作呢。?
剩下的就不多扯了 : 让我们看看微软是如何介绍 timestamp的并发控制的: 补充下  查询当前数据库时间戳 :   select @@dbts
create table mytest2 (mykey int primary key ,myvalue int, ts timestamp);go insert into mytest2 (mykey, myvalue) values (1, 0);go insert into mytest2 (mykey, myvalue) values (2, 0);godeclare @t table (mykey int);update mytest2set myvalue = 2 output inserted.mykey into @t(mykey) where mykey = 1 and ts = myvalue;if (select count(*) from @t) = 0 begin raiserror ('error changing row with mykey = %d' ,16 -- severity. ,1 -- state ,1) -- mykey that was changed end;
拉萨分类信息网,免费分类信息发布

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录