weizhi 2012-09-12 18:03:24 3716次浏览 2条回复 0 0 0

到底什么是时间戳? 也许我这么问很不专业,请原谅我这个才入门的菜菜。以前看书以为时间戳就是从1970年01月01日8:00到现在的秒数,这个”时间戳“被用来存储时间记录在数据库中。我看的有的视频教程也是这么说的,今天用到了时间戳上网找了点资料。我看了博客园的文章对时间戳是这么描述的:(原文网址:http://www.cnblogs.com/myaspnet/archive/2011/10/27/2226750.html) 一直对时间戳这个概念比较模糊,相信有很多朋友也都会误认为:时间戳是一个时间字段,每次增加数据时,填入当前的时间值。其实这误导了很多朋友。

时间戳:数据库中自动生成的唯一二进制数字,与时间和日期无关的, 通常用作给表行加版本戳的机制。存储大小为 8个字节。

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

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

在控制并发时起到作用: 用户A/B同时打开某条记录开始编辑,保存是可以判断时间戳,因为记录每次被更新时,系统都会自动维护时间戳,所以如果保存时发现取出来的时间戳与数据库中的时间戳如果不相等,说明在这个过程中记录被更新过,这样的话可以防止别人的更新被覆盖[。 看了这篇文章以后我就对我以前的概念怀疑了,到底时间戳怎么理解更好呢??

  • 回复于 2012-09-12 22:49 举报

    说TimeStamp表示从1970年以来的秒数,是没有错的。但称为UNIX时间可能更准确定。
    但是,UNIX时间由于我们知道的,字长有限制的,所以,到了若干年后,会over float。其次,按秒计算,对于数据库来说,尤其是并发密集访问的情况下,按秒计算的粒度过粗了。因此,有了另一个类似的timeStamp。这个,更倾向于stamp。
    只是不同的数据系统中,把timestamp应用成一个纯stamp,也就是用于区别时间轴上的先后顺序。
    SQL对此是有标准的,但具体实现时,MSSQL和MySQL可能不同,不同版本的数据库也可能不同。记得早先MySQL有一个版本的TimeStamp就与现在的不同。同理,PHP的time()和MySQL的NOW(),也就不同。
    说timeStamp与日期和时间无关,恐怕说不过去。至少,在日期和时间的先后顺序上,他们是严格对应的,且1对1映射。

  • 回复于 2012-09-13 07:17 举报

    解释的真清楚,太感激了~

您需要登录后才可以回复。登录 | 立即注册