是否有可能为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()
产生类似:
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()仍不能保证唯一的值。
问题内容: 说我有 ID的* 记录 * 我希望能够通过下一个/上一个链接导航到另一个。 问题是,我不知道 如何获取具有最近的较高ID的记录 。 因此,当我有一个 ID为ID 的记录时,我需要能够提取下一个现有记录,即为。 该查询可能看起来像 如何获取下一个/上一个记录而不获取整个结果集并手动迭代? 我正在使用MySQL 5。 问题答案: 下一个: 以前的:
问题内容: 不幸的是,SQL并不是很容易找到我。我有两个表,一个表和一个表。 贷款支付表: ID(主键),LoanID(与贷款表上的ID匹配),PaymentDate,Amount等。 我需要一条sql语句,该语句可以给我每个月输入的最后一笔付款(如果有的话)。我目前的说法没有给我结果。还存在一个问题,有时在该月的最大日期有时会有平局,因此我也必须能够处理该问题(我的想法是在平局的情况下选择最大的
本文向大家介绍检查一列以获取MySQL中的唯一值,包括了检查一列以获取MySQL中的唯一值的使用技巧和注意事项,需要的朋友参考一下 您可以为此使用子查询。让我们首先创建一个演示表 使用insert命令在表中插入一些记录。查询如下- 使用select语句显示表中的所有记录。查询如下- 输出如下 这是检查列唯一值的查询 输出如下
问题内容: 我有一个包含以下各列的模型: 我有索引和。 现在,我想获取由排序的每个对象的第一个日志。 一种方法是对每个用户名运行以下查询: 但这显然会查询数据库很多次(等于用户名的数量)。有什么方法可以只执行一个数据库查询吗? 问题答案: 另一种情况: 返回每个“第一”条目 的整行。 这种Ruby语法应该可以工作:
问题内容: 请考虑下表: 在这里,我要找回它们是具有独特组合的记录,和。如果存在两个或多个这些字段的唯一组合,我想选择其中的第一个。 作为上表数据的示例,我需要的输出是 (由于记录3和4具有相同的组合,我想只记录3,因为它是第一次出现) 我可以使用一条SQL语句执行此操作吗? 问题答案:
问题内容: 我的数据库表中具有以下格式的数据: 该列将来自该列的数据作为父记录。带有值的表示根项目。我需要编写查询以按以下顺序获取数据: 我需要得到根记录(与记录为0),然后是所有和这根记录,然后获得下根的记录,然后和在这个根记录等等。 问题答案: 我在这里提出的解决方案使用了物化路径的概念。以下是使用样本数据的实例化路径的示例。我希望它可以帮助您理解物化路径的概念: 每个节点都有一个实例化路径,