欢迎进入武汉轻洽网络技术有限公司官方网站!
服务热线:027-51831034,13971151027
   2年前 (2017-06-26)  Sql |   抢沙发  29 
文章评分 0 次,平均分 0.0

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

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

使用某一行中的timestamp列可以很容易地确定该行中的任何自上次读取以后是否发生了更改。 如果对行进行了更改,就会更新该时间戳。 如果没有对行进行更改,则该时间戳将与以前读取该行时的时间戳一致。 若要返回数据库的当前时间戳,请使用@@DBTS。

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

rowversion的数据类型为timestamp数据类型的同义词,并具有数据类型同义词的行为。 在 DDL 语句,请尽量使用rowversion而不是timestamp。 有关详细信息,请参阅数据类型同义词
(Transact-SQL)。

在 CREATE TABLE 或 ALTER TABLE 语句中,不必为timestamp数据类型指定列名,例如:

CREATE TABLE ExampleTable (PriKey int PRIMARY KEY, timestamp);

如果不指定列名,则 Microsoft SQL Server 2005 数据库引擎将生成timestamp列名;但rowversion同义词不具有这样的行为。 在使用rowversion时,必须指定列名。

注意:

在使用其中的 SELECT 列表中具有timestamp列的 SELECT INTO 语句时,可能会生成重复的时间戳。 建议不要以这种方式使用timestamp。

不可为空的timestamp列在语义上等同于binary(8)列。 可为空的timestamp列在语义上等同于varbinary(8)列。

 

除特别注明外,本站所有文章均为轻洽网络原创,转载请注明出处来自https://www.qingqia.net/434.html

关于

发表评论

暂无评论

切换注册

登录

忘记密码 ?

您也可以使用第三方帐号快捷登录

切换登录

注册

扫一扫二维码分享