教程学院
图像设计 多媒体类 机械制图 办公软件 操作系统 系统编程 网站编程 网页制作 数据库类 网络路由 网络工程 网络安全 考试认证
firefox火狐浏览器下载
酷网学院
CAD
AutoCad Cam350 ProEngineer GCcam MATLAB Unigraphics SolidWorks CAXA Solid3000 Cimatron EdgeCAM
系统
安全 防火墙 病毒 WinXP Win2003 Vista
数据库
编程
网络
精彩图库
  当前位置: 库库中文网 · 数据库类教程 · MSSQL教程 · MsSql综合技巧

SQL Server里地TimeStamp是怎么样运用地?与Binary(8)又是啥关系?

 
学院最新推荐文章
PS教程推荐
 
『SQL Server里地TimeStamp是怎么样运用地?与Binary(8)又是啥关系?』如果文章有大量图片,显示会较慢,请等待图片下载完成
 
作者:kingmax5… 来源:C.S.D.N 点击数: 更新时间:2008-7-23 
SQL Server里的TimeStamp是如何使用的?与Binary(8)又是什么关系?
这个问题第1个回答:
e 没用过 顶顶
这个问题第2个回答:
SQL code

create table xx(id int, timestamp)



insert into xx(id) select 1



select * from xx




这个问题第3个回答:
防止并发用的,可以和bigint相互转化
这个问题第4个回答:
沒關系,是記錄版本用的
这个问题第5个回答:
SQL code

create table tb_test(id int, ts timestamp)



insert tb_test(id) select 1

union all select 2

union all select 3

union all select 4



select *, nts=cast(ts as bigint) from tb_test

/*

id          ts                 nts

----------- ------------------ --------------------

1           0x0000000000001F41 8001

2           0x0000000000001F42 8002

3           0x0000000000001F43 8003

4           0x0000000000001F44 8004



(4 row(s) affected)



*/



drop table tb_test


这个问题第6个回答:
SQL code

declare @n bigint

set @N=8001

select cast(@N as timestamp)



/*

------------------

0x0000000000001F41



(1 row(s) affected)

*/


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

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

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

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

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) 列。

这个问题第8个回答:
路过,
大多数情况下估计是等同效果.
这个问题第9个回答:
实际应用中使用它吗?
这个问题第10个回答:
to dobear_0922:

看样子,本帖的关键点还是在于:怎么使用TimeStamp进行防止并发?

多谢!

这个问题第11个回答:
anyone?
这个问题第12个回答:
学习
这个问题第13个回答:
时间戳,可以转换为时间。。
可以记录每次操作的时间。。
这个问题第14个回答:
楼上的回答要扣分了哈:
SQL  Server  timestamp  是二进制数字。
SQL  Server  timestamp  数据类型与时间和日期无关。

这个问题第15个回答:
楼上的回答要扣分了哈:
SQL  Server  timestamp  是二进制数字。
SQL  Server  timestamp  数据类型与时间和日期无关。
--------------------------------------------------------
timestamp确实可以转为datetime


timestamp应该是用于防止并发冲突的吧.


这个问题第16个回答:
timestamp还可以在数据同步时判定历史数据是否更新
这个问题第17个回答:
timestamp 这种数据类型表现自动生成的二进制数,确保这些数在数据库中是唯一的
binary 是二进制数据类型,可以认为,前者是后者的一个特例(即子集),只不过系统为你做了一部分工作。

timestamp既然命名为时间戳,当然也记录了日期信息,只不过是以二进制方式存储的。但是它的值范围小于datetime,也属于datetime的子集。


SQL code

declare @n bigint

set @N=8001

select cast(@N as timestamp)



declare @d datetime

set @d=8001  -- 以1900-1-1为初始时间按dd去dateadd,8001dd.

select cast(@d as timestamp)



declare @x datetime

set @x='1921-11-28'

select cast(@x as binary(8))


这个问题第18个回答:
主要作用应该是如16楼所述。
并发通常用 uniqueidentifier 值。

】【关闭窗口
·上页:
·下页:
相关文章
 
     数据库类教程 - MsSql综合技巧
普通教程SQL Server 2008升级顾问
普通教程迁移 Reporting Services
普通教程SQL Server 2008升级报表服务器
普通教程SQL Server 2008 升级Reporting
普通教程SQL Server 2008示例之奥地利广
普通教程SQL Server 2008 示例之微软IT部
普通教程SQL Server 2008示例之日立咨询
普通教程SQL Server2008示例之CyberSavv
普通教程SQL Server 2008示例之CareGrou
普通教程微软商业智能技术详细解说
普通教程通过数据说明和生成报表整合企业
advertisement
关于站点 - 广告服务 - 联系我们 - 版权隐私 - 免责声明 - 合作伙伴 - 程序支持 - 网站地图 - 返回顶部
网站文本地图
版权所有:库库中文 2005-2007 欢迎各种媒体转载我们的原创作品[转载请注明出处]
copyright © 2005-2008 www.QQGB.com online services. all rights reserved. 蜀ICP备05015578
Template designed by Virus. Optimized for 1024x768 to Firefox,Opera and MS-IE6. Site powered by EQL.
红盾
热爱电脑,热爱生活
拥有电脑,拥有生命
让我们享受拥有电脑的时光