tsql – T-SQL“timestamp”覆盖“rowversion”数据类型列

我正在使用Miscrosoft SQL Server 2012,因为在这 article中说:

The timestamp syntax is deprecated. This feature will be removed in a
future version of Microsoft SQL Server. Avoid using this feature in
new development work,and plan to modify applications that currently
use this feature.

我决定使用“rowversion”列而不是“timestamp”列.所以,我创建了下表:

CREATE TABLE [dbo].[TestTable]
(
     [Col001] [INT] NOT NULL,[Col002] [CHAR](2) NOT NULL
     ...,[Col00N]  [DATETIME2] NOT NULL,[RowVersionID] [ROWVERSION] NOT NULL,CONSTRAINT [PK_ProtoSurveyGlobalizationChanges_RowVersionID] PRIMARY KEY CLUSTERED 
     (
        [RowVersionID] ASC
     )WITH (PAD_INDEX = OFF,STATISTICS_NORECOMPUTE = OFF,IGNORE_DUP_KEY = OFF,ALLOW_ROW_LOCKS = ON,ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] 
) ON [PRIMARY]

一切都看起来很好,直到我按下“ALT F1”组合,给我关于我的表的信息(如列详细信息),我看到“RowVersionID”列标记为“timestamp”类型.

接下来认为我已经完成了,使用SQL Server Management Studio 2012“删除并创建我的表”,“生成的SQL”更改了我的原始查询,如下所示:

[RowVersionID] [timestamp] NOT NULL

为什么服务器没有使用我最初设置的类型,为什么在文章中我建议不要使用“timestamp”,但不知何故服务器正在选择它?

解决方法

它们是同义词,服务器无法告诉(一旦创建表格)您实际用于创建表格的单词.

显然,在深度深处,时间戳被弃用的消息还没有达到负责编写SQL Server脚本组件的人 – 所以脚本仍然说时间戳.

相关文章

本篇内容主要讲解“sqlalchemy的常用数据类型怎么使用”,感...
今天小编给大家分享一下sqlServer实现分页查询的方式有哪些的...
这篇文章主要介绍“sqlmap之osshell怎么使用”,在日常操作中...
本篇内容介绍了“SQL注入的知识点有哪些”的有关知识,在实际...
1. mssql权限sa权限:数据库操作,文件管理,命令执行,注册...
sql执行计划如何查看?在SPL庞大的数据中我们不知道如何查看...