一尘不染

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

sql

是否有可能为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");

阅读 172

收藏
2021-03-10

共1个答案

一尘不染

很快将有一天(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()仍不能保证唯一的值。

2021-03-10