MySQL生成32位UUID 您所在的位置:网站首页 uuid生成32位 MySQL生成32位UUID

MySQL生成32位UUID

2024-07-13 05:40| 来源: 网络整理| 查看: 265

有时MySQL数据库某些表的ID需要使用UUID值(由一组32位数的16进制数字所构成)作为唯一识别码。

可以通过MySQL自带的UUID() 函数来生成:

select UUID(); 结果为:0a3eed30-9ad5-11e9-9835-b8ee6591991d

这样获取的是带 “-” 分隔符的UUID,32位字符加上分隔符共36位,不符合要求,可以通过replace() 函数对获取到的UUID的分隔符替换处理如下:

SELECT REPLACE(UUID(), '-', ''); 结果为:eccc72479ad511e99835b8ee6591991d

则获取到了没有分隔符的32为UUID。

注:(以下介绍摘自百度百科) UUID是指在一台机器上生成的数字,它保证对在同一时空中的所有机器都是唯一的。通常平台会提供生成的API。按照开放软件基金会(OSF)制定的标准计算,用到了以太网卡地址、纳秒级时间、芯片ID码和随机数。 UUID由以下几部分的组合: (1)当前日期和时间,UUID的第一个部分与时间有关,如果你在生成一个UUID之后,过几秒又生成一个UUID,则第一个部分不同,其余相同。 (2)时钟序列。 (3)全局唯一的IEEE机器识别号,如果有网卡,从网卡MAC地址获得,没有网卡以其他方式获得。 UUID的唯一缺陷在于生成的结果串会比较长。关于UUID这个标准使用最普遍的是微软的GUID(Globals Unique Identifiers),标准的UUID格式为:xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx (8-4-4-4-12)。 (4)在 hibernate 中, 采用 IP-JVM启动时间-当前时间右移32位-当前时间-内部计数(8-8-4-8-4)来组成UUID。



【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有