栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

我可以为MySQL中的每个记录获取唯一的TIMESTAMP吗?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

我可以为MySQL中的每个记录获取唯一的TIMESTAMP吗?

很快将有一天(5.6.4),MySQL将在TIMESTAMP列中提供小数秒,但是即使在小数秒中也不能保证是唯一的,尽管从理论上讲,它们通常是唯一的,特别是如果将MySQL限制为单个线。

如果需要按时间顺序排列的唯一编号,则可以使用UUID。

SELECT UUID()
产生类似:

45f9b8d6-8f00-11e1-8920-842b2b55ce56

一段时间后:

004b721a-8f01-11e1-8920-842b2b55ce56

UUID的前三个部分由时间组成,但是,它们的顺序是从最高精度到最小精度,因此您需要使用

SUBSTr()
和反转前三个部分
CONCAt()

SELECT CONCAt(SUBSTr(UUID(), 15, 4), '-', SUBSTr(UUID(), 10, 4),  '-', SUBSTr(UUID(), 1, 8))

产量:

11e1-8f00-45f9b8d6

显然,您不能将这样的函数用作默认值,因此必须在代码中进行设置,但这是保证唯一的时间顺序值。UUID()的工作级别远低于秒(时钟周期),因此可以确保每次调用都具有唯一性,并且开销较低(没有像auto_increment那样的锁定)。

在数据库服务器上使用UUID()可能比

microtime()
在应用程序服务器上使用类似功能(例如PHP的功能)更可取,因为您的数据库服务器更加集中。您可能有多个应用程序(Web)服务器,该服务器可能生成冲突值,而microtime()仍不能保证唯一的值。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/414817.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号