24小时热门版块排行榜    

查看: 3553  |  回复: 10
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

agaduma

新虫 (小有名气)

[交流] 关于数据库中使用时间戳的科普 已有7人参与

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

时间戳的变化说明数据库中某一个值发生了改变。简单的说时间戳的变化和后台操作有关,和登录无关

================
    一直对时间戳这个概念比较模糊,相信有很多朋友也都会误认为:时间戳是一个时间字段,每次增加数据时,填入当前的时间值。其实这误导了很多朋友。
时间戳:数据库中自动生成的唯一二进制数字,与时间和日期无关的, 通常用作给表行加版本戳的机制。存储大小为 8个字节。

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

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

在控制并发时起到作用:
    用户A/B同时打开某条记录开始编辑,保存是可以判断时间戳,因为记录每次被更新时,系统都会自动维护时间戳,所以如果保存时发现取出来的时间戳与数据库中的时间戳如果不相等,说明在这个过程中记录被更新过,这样的话可以防止别人的更新被覆盖.
回复此楼

» 猜你喜欢

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

sdqdxmch

新虫 (正式写手)


小木虫: 金币+0.5, 给个红包,谢谢回帖
哪儿粘贴过来的?

发自小木虫Android客户端
3楼2017-07-05 18:41:45
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 11 个回答

haidong9058

金虫 (职业作家)


小木虫: 金币+0.5, 给个红包,谢谢回帖
???????????÷??×??á????°??????????°

[ ·?×????ú°? https://muchong.com/3g ]
2楼2017-07-05 18:38:17
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

gsf266

铜虫 (小有名气)


小木虫: 金币+0.5, 给个红包,谢谢回帖
他想说的是,时间戳和系统是否更改有关系,跟自己登录没有关系。是不是楼主?
4楼2017-07-05 18:52:30
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

haidong9058

金虫 (职业作家)

???÷?????÷°×°?

[ ·?×????ú°? https://muchong.com/3g ]
5楼2017-07-05 20:10:14
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
普通表情 高级回复 (可上传附件)
信息提示
请填处理意见