关于对时间戳timestamp理解
来源:互联网 发布:旅游门户网站源码 编辑:程序博客网 时间:2024/05/18 00:52
关于对时间戳timestamp理解
一直对时间戳的概念模糊,并且网上也有很多朋友也都误认为:是一个时间字段,每次增加数据时,填入当前的时间值。导致也误导了很多朋友。
这次看了很多资料,纠正一下这个错误,自己也搞清楚:数据库中自动生成的唯一二进制数字,与时间和日期无关的, 通常用作给表行加版本戳的机制。存储大小为 8 个字节。
每个数据库都有一个计数器,当对数据库中包含 timestamp 列的表执行插入或更新操作时,该计数器值就会增加。该计数器是数据库时间戳。这可以跟踪数据库内的相对时间,而不是时钟相关联的实际时间。一个表只能有一个 timestamp 列。每次修改或插入包含 timestamp 列的行时,就会在 timestamp 列中插入增量数据库时间戳值。这一属性使 timestamp 列不适合作为键使用,尤其是不能作为主键使用。对行的任何更新都会更改 timestamp 值,从而更改键值。如果该列属于主键,那么旧的键值将无效,进而引用该旧值的外键也将不再有效。如果该表在动态游标中引用,则所有更新均会更改游标中行的位置。如果该列属于索引键,则对数据行的所有更新还将导致索引更新。
使用某一行中的 timestamp 列可以很容易地确定该行中的任何值自上次读取以后是否发生了更改。如果对行进行了更改,就会更新该时间戳值。如果没有对行进行更改,则该时间戳值将与以前读取该行时的时间戳值一致。若要返回数据库的当前时间戳值,请使用 @@DBTS。
在控制并发时起到作用:
用户A/B同时打开某条记录开始编辑,保存是可以判断时间戳,因为记录每次被更新时,系统都会自动维护时间戳,所以如果保存时发现取出来的时间戳与数据库中的时间戳如果不相等,说明在这个过程中记录被更新过,这样的话可以防止别人的更新被覆盖。
参考:http://blog.csdn.net/xushichang/archive/2009/08/01/4399316.aspx
http://www.qqgb.com/DataDB/MSSQL/Sql2000JiQiao/DataDB_182792.html
- 关于对时间戳timestamp理解
- 关于对时间戳timestamp理解
- [SQL Server]关于对时间戳timestamp理解
- 关于Unix时间戳(Unix timestamp)
- 关于时间戳timestamp的说明
- 关于Unix时间戳(Unix timestamp)
- FFMPEG 关于对时间戳转换的理解
- FFMPEG 关于对时间戳转换的理解
- 关于Postgre中的Timestamp(时间戳)格式。
- [sqlserver]timestamp 时间戳
- PHP 时间戳 timestamp
- 时间戳timestamp
- oracle 时间戳TIMESTAMP
- 时间戳TimeStamp处理
- 时间戳-timestamp
- iOS 时间戳Timestamp
- 关于日期时间操作工具类DateUtil(二) -----对java.sql.Timestamp 的操作.
- scala对时间(date)字符串转化为时间戳timestamp的实现
- 智能家居的遐想...
- c#的attribute program
- Netbeans6.8+GlassFishV3体验JEE 6
- 【转】自编汉字测试软件(有删减,仅保留文本比较算法部分)
- JPA是什么!
- 关于对时间戳timestamp理解
- 在C++builder中用伪造的dll生成的lib文件可正常调用vc写的dll
- 【转】高级动态规划
- 熊猫烧香制造者李俊出狱以后的六种出路
- SIP消息头域的说明
- 在Fedora 12上安装谷歌应用程序
- 九 java面向对象程序设计(this关键字)
- 【转】编辑距离
- 十 java面向对象程序设计(static关键字)