广告
返回顶部
首页 > 资讯 > 数据库 >MySQL的UUID
  • 150
分享到

MySQL的UUID

2024-04-02 19:04:59 150人浏览 独家记忆
摘要

Mysql在初始化的时候会产生一个UUID:[root@mha03 opt]# mysql/bin/mysqld --initialize --user=mysql --basedir=/opt/mysql

Mysql在初始化的时候会产生一个UUID:

[root@mha03 opt]# mysql/bin/mysqld --initialize --user=mysql --basedir=/opt/mysql/ --datadir=/opt/mysql/data/

2019-08-14T03:42:26.588685Z 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details).

2019-08-14T03:42:26.899821Z 0 [Warning] InnoDB: New log files created, LSN=45790

2019-08-14T03:42:26.944820Z 0 [Warning] InnoDB: Creating foreign key constraint system tables.

2019-08-14T03:42:27.023508Z 0 [Warning] No existing UUID has been found, so we assume that this is the first time that this server has been started. Generating a new UUID: 88e4e8ea-be45-11e9-b3D0-000c29c8d0f8.

2019-08-14T03:42:27.024729Z 0 [Warning] Gtid table is not ready to be used. Table 'mysql.gtid_executed' cannot be opened.

2019-08-14T03:42:27.026127Z 1 [Note] A temporary passWord is generated for root@localhost: &didSDjQn2dk


UUID 是 通用唯一识别码(Universally Unique Identifier)的缩写,是一种软件建构的标准,亦为 开放软件基金会 组织在 分布式计算 环境领域的一部分。其目的,是让分布式系统中的所有元素,都能有唯一的辨识信息,而不需要通过中央控制端来做辨识信息的指定。如此一来,每个人都可以创建不与其它人冲突的UUID。在这样的情况下,就不需考虑数据库创建时的名称重复问题。目前最广泛应用的UUID,是 微软公司 的 全局唯一标识符 (GUID ),而其他重要的应用,则有linux ext2/ext3文件系统、LUKS加密分区、GNOME、KDE、Mac OS X等等。另外我们也可以在e2fsprogs包中的UUID库找到实现。



定义

UUID是由一组32位数的16进制数字所构成,所以UUID理论上的总数为16^32=2^128,约等于3.4 x 10^38。也就是说若每纳秒产生1兆个UUID,要花100亿年才会将所有UUID用完。

UUID的标准型式包含32个 16进制 数字,以连字号分为五段,形式为8-4-4-4-12的32个字符。示例:

550e8400-e29b-41d4-a716-446655440000

UUID亦可刻意重复以表示同类。例如说 微软 的 COM 中,所有组件皆必须实现出 IUnknown 接口,方法是产生一个代表IUnknown的UUID。无论是程序试图访问组件中的IUnknown接口,或是实现IUnknown接口的组件,只要IUnknown一被使用,皆会被参考至同一个ID:00000000-0000-0000-C000-000000000046。  [1]  

组成

UUID是指在一台机器上生成的数字,它保证对在同一时空中的所有机器都是唯一的。通常平台会提供生成的api。按照 开放软件基金会 (OSF)制定的标准计算,用到了以太网卡地址、纳秒级时间、芯片ID码和随机数。

UUID由以下几部分的组合:

(1)当前日期和时间,UUID的第一个部分与时间有关,如果你在生成一个UUID之后,过几秒又生成一个UUID,则第一个部分不同,其余相同。

(2)时钟序列。

(3)全局唯一的IEEE机器识别号,如果有网卡,从网卡MAC地址获得,没有网卡以其他方式获得。

UUID的唯一缺陷在于生成的结果串会比较长。关于UUID这个标准使用最普遍的是微软的GUID(Globals Unique Identifiers)。在ColdFusion中可以用CreateUUID()函数很简单地生成UUID,其格式为:xxxxxxxx-xxxx- xxxx-xxxxxxxxxxxxxxxx(8-4-4-16),其中每个 x 是 0-9 或 a-f 范围内的一个十六进制的数字。而标准的UUID格式为:xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx (8-4-4-4-12),可以从cflib 下载CreateGUID() UDF进行转换。  [2]  

(4)在 hibernate(Java ORM框架)中, 采用 IP-JVM启动时间-当前时间右移32位-当前时间-内部计数(8-8-4-8-4)来组成UUID



UUID作用:

UUID 的目的是让 分布式系统 中的所有元素,都能有唯一的辨识资讯,而不需要透过中央控制端来做辨识资讯的指定。如此一来,每个人都可以建立不与其它人冲突的 UUID。在这样的情况下,就不需考虑数据库建立时的名称重复问题。目前最广泛应用的 UUID,即是微软的 Microsoft's Globally Unique Identifiers (GUIDs),而其他重要的应用,则有 Linux ext2/ext3 档案系统、LUKS 加密分割区、GNOME、KDE、Mac OS X 等等。 

郑州不孕不育医院:Http://jbk.39.net/yiyuanzaixian/zztjyy/


UUID应用:


使用UUID的好处在分布式的软件系统中(比如:DCE/rpc, COM+,CORBA)就能体现出来,它能保证每个节点所生成的标识都不会重复,并且随着WEB服务等整合技术的发展,UUID的优势将更加明显。根据使用的特定机制,UUID不仅需要保证是彼此不相同的,或者最少也是与公元3400年之前其他任何生成的通用唯一 标识符 有非常大的区别。UUID最少在3000+年内不会重复。

通用唯一标识符还可以用来指向大多数的可能的物体。微软和其他一些软件公司都倾向使用全球唯一标识符(GUID),这也是通用唯一标识符的一种类型,可用来指向组建对象模块对象和其他的 软件组件 。第一个通用唯一标识符是在网络计算机系统(NCS)中创建,并且随后成为 开放软件基金会 (OSF)的 分布式计算环境 (DCE)的组件。


您可能感兴趣的文档:

--结束END--

本文标题: MySQL的UUID

本文链接: https://www.lsjlt.com/news/40353.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL的UUID
    MySQL在初始化的时候会产生一个UUID:[root@mha03 opt]# mysql/bin/mysqld --initialize --user=mysql --basedir=/opt/mysql...
    99+
    2022-10-18
  • mysql中“UUID();”的用法以及用处
            今天在sql语句学习中,看到了UUID();的语句, 查询学习后,做出记录。         在SQL语句中,使用SELECT UUID()语句可以获取一个随机生成的UUID(Universally Unique Iden...
    99+
    2023-10-11
    mysql 数据库
  • Mysql修改server uuid的方法分享
    问题来源: 如果从服务器是克隆的主服务器,那么server-uuid的值肯定是一样的,不然后面主从复制报错误1593,修改以后重启mysql 下面就来给大家介绍相关的解决方法,话不多说了,来一起看看详细的...
    99+
    2022-10-18
  • mysql uuid是不是有序增加的
    今天就跟大家聊聊有关mysql uuid是不是有序增加的,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。 A UUID i...
    99+
    2022-10-18
  • MySQL批量插入不重复的UUID
    使用场景 有时候需要给表中已有数据填充一个字段为UUID, 比如更新所有ID等。 操作思路 先给每一条数据增加一个UUID将UUID中的-替换为空 方案一:一次性替换sql select REPLACE ( UUID( ), ...
    99+
    2023-09-05
    mysql sql 数据库
  • mybatis+MySQL UUID主键生成策略
    <insert id="insert" parameterType="com.gzwb.wbspm.model.SpmInvoice" >  <selectKey k...
    99+
    2022-10-18
  • postgresql中的UUID
      默认安装的postgresql是不带UUID函数的,为了生成UUID,我们不得不在客户端生成。其实在postgresql的安装目录下已经存在这样的函数定义,我们只需将其import进来即可     从安装目录次啊share/contri...
    99+
    2015-05-01
    postgresql中的UUID 数据库入门 数据库基础教程 数据库 mysql
  • mybatis+mysql环境下 uuid存储优化
    1问题 uuid采用char(32)或char(36)存储的话,需要占用32或36个字节。为节省存储空间,改为binary(16),占用16字节。对于500W行的表,可节省7.4G的空间。 mybatis中没有...
    99+
    2018-08-07
    mybatis+mysql环境下 uuid存储优化
  • 详解:MySQL自增ID与UUID的优缺点及选择建议,MySQL有序uuid与自定义函数实现
    文章目录 1.自增ID的优缺点1.1 优点1.2 缺点1.3 不适合以自增ID主键作为主键的情况 2.UUID作为主键2.1 介绍2.2 优点2.3 缺点 3.有序UUID作为主键3....
    99+
    2023-09-30
    mysql 数据库 java
  • MySQL的server_uuid获取之uuid()函数和uuid_short()函数
    1、uuid()函数 String *Item_func_uuid::val_str(String *str)   {   ...
    99+
    2022-10-18
  • MySQL为什么不能用uuid做主键
    今天小编给大家分享一下MySQL为什么不能用uuid做主键的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起...
    99+
    2022-10-19
  • UUID already exists
    VirtualBox将旧的vdi文件加入到新的系统中会报:UUID already exists 。 重新创建uuid: cd C:\Program Files\Oracle\VirtualBox\ VBo...
    99+
    2022-10-18
  • python uuid库的使用
    python 的uuid库是用来生成一串唯一表示的包,uuid是一个 32 位的16进制数,用来设置唯一的辨识信息,具体uuid功能查看维基百科 uuid库的使用方法(uuid使用文档翻译): uuid 帮助模块: uuid - UUI...
    99+
    2023-01-31
    python uuid
  • golang uuid转string
    在Golang中,UUID是一个非常重要的类型,它用于生成唯一标识符。在处理UUID时,我们经常需要将其转换成字符串类型。本文将介绍如何在Golang中将UUID转换为字符串类型的方法。使用fmt.Sprintf函数fmt.Sprintf可...
    99+
    2023-05-14
  • python 生成 uuid
    Python 中可以使用内置的 uuid 模块来生成 UUID。 示例代码如下: import uuid# 生成随机 UUIDrandom_uuid = uuid.uuid4()print(random_uuid)# 生成带有命名空...
    99+
    2023-09-14
    python 开发语言 numpy
  • MySql主键id不推荐使用UUID的原因分析
    目录前言规范原因前言 昨天在某个技术群中,有个老哥发送了一个技术视频:讲的是一个毕业生面试被问,前后端的交互ID是使用自增的吗?为什么不使用UUID?最后的解释是说性能问题,这个引起了我的兴趣,查了一下资料总结一下。 规...
    99+
    2023-03-06
    MySql主键id不推荐使用UUID MySql主键id MySql主键不推荐使用UUID
  • Mysql分析设计表主键为何不用uuid
    目录一、mysql和程序实例1.1 建表1.2 测试1.3 程序写入结果1.4 效率测试结果二、使用uuid和自增id的索引结构对比2.1 使用自增id的内部结构2.2 使用uuid...
    99+
    2022-11-13
  • MySQL为什么不建议用UUID做innodb主键
    这篇文章将为大家详细讲解有关MySQL为什么不建议用UUID做innodb主键,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 1).UUID...
    99+
    2022-10-18
  • MySql主键id不推荐使用UUID的原因是什么
    本文小编为大家详细介绍“MySql主键id不推荐使用UUID的原因是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“MySql主键id不推荐使用UUID的原因是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧...
    99+
    2023-07-05
  • Mysql数据库自增id、uuid与雪花id详解
    目录概念介绍三种主键聚簇索引与非聚簇索引自增iduuid雪花id与应用总结概念介绍 三种主键 自增id :1 2 3 4 5…… uuid :UUID是Universally Unique I...
    99+
    2023-02-28
    mysql自增id和uuid 数据库union的用法 mysql自增主键
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作