是否有可能为MySQL中的每个记录获取唯一的时间戳值?
我创建了一个样本表
CREATE TABLE t1 (id int primary key, name varchar(50), ts TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP );
并运行了一些示例“ INSERTIONS”,似乎时间戳记值已重复。
e.g insert into t1(id,name) values(1,"test");
很快将有一天(5.6.4),MySQL将在TIMESTAMP列中提供小数秒,但是即使在小数秒中也不能保证是唯一的,尽管从理论上讲,它们通常是唯一的,特别是如果将MySQL限制为单个线。
如果需要按时间顺序排列的唯一编号,则可以使用UUID。
SELECT UUID() 产生类似:
SELECT UUID()
45f9b8d6-8f00-11e1-8920-842b2b55ce56
一段时间后:
004b721a-8f01-11e1-8920-842b2b55ce56
UUID的前三个部分由时间组成,但是,它们的顺序是从最高精度到最小精度,因此您需要使用SUBSTR()和反转前三个部分CONCAT():
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()仍不能保证唯一的值。
microtime()