mysql 使用uuid主键_MySQL UUID和主键(二十二)

MySQL UUID 主键详解
本文介绍了MySQL中的UUID概念及其作为主键的应用。探讨了UUID作为主键的优点与不足,并提供了如何在MySQL中生成和使用UUID的具体示例。
82200184a76ffa5a19ed8ab9d89a81e1.png

本教程将向您介绍MySQL UUID,并演示如何将其用作表的主键(PK),并讨论将其用作主键的优缺点。

MySQL UUID简介

UUID代表通用唯一标识符。UUID是基于”RFC 4122“通用唯一标识符(UUID)URN命名空间”)定义的。

UUID被设计为在空间和时间全球独一无二的数字。 预期两个UUID值是不同的,即使它们在两个独立的服务器上生成。

在MySQL中,UUID值是一个128位的数字,表示为以下格式的十五进制数字的utf8字符串:

aaaaaaaa-bbbb-cccc-dddd-eeeeeeeeeeee

要生成UUID值,请使用UUID()函数,如下所示:

UUID()

UUID()函数返回符合RFC 4122中描述的UUID版本1的UUID值。

例如,以下语句使用UUID()函数来生成UUID值:

mysql> SELECT UUID();+--------------------------------------+| UUID() |+--------------------------------------+| 9d6212cf-72fc-11e7-bdf0-f0def1e6646c |+--------------------------------------+1 row in set

MySQL UUID与自动递增INT作为主键

优点

使用UUID作为主键具有以下优点:

  • UUID值在表,数据库甚至在服务器上都是唯一的,允许您从不同数据库合并行或跨服务器分发数据库。
  • UUID值不会公开有关数据的信息,因此它们在URL中使用更安全。例如,如果ID为10的客户通过URL: http://www.example.com/customers/10/ 访问他的帐户,那么很容易猜到有一个客户11,12等,这可能是攻击的目标。
  • 可以在避免往返数据库服务器的任何地方生成UUID值。它也简化了应用程序中的逻辑。 例如,要将数据插入到父表和子表中,必须首先插入父表,获取生成的id,然后将数据插入到子表中。通过使用UUID,可以生成父表的主键值,并在事务中同时在父表和子表中插入行。

缺点

除了优势之外,UUID值也有一些缺点:

  • 存储UUID值(16字节)比整数(4字节)或甚至大整数(8字节)占用更多的存储空间。
  • 调试似乎更加困难,想像一下WHERE id ='9d6212cf-72fc-11e7-bdf0-f0def1e6646c'和WHERE id = 10那个舒服一点?
  • 使用UUID值可能会导致性能问题,因为它们的大小和没有被排序。

MySQL UUID解决方案

在MySQL中,可以以紧凑格式(BINARY)存储UUID值,并通过以下功能显示人机可读格式(VARCHAR):

  • UUID_TO_BIN
  • BIN_TO_UUID
  • IS_UUID

请注意,UUID_TO_BIN(),BIN_TO_UUID()和IS_UUID()函数仅在MySQL 8.0或更高版本中可用。

UUID_TO_BIN()函数将UUID从人类可读格式(VARCHAR)转换成用于存储的紧凑格式(BINARY)格式,并且BIN_TO_UUID()函数将UUID从紧凑格式(BINARY)转换为人类可读格式(VARCHAR)。

如果参数是有效的字符串格式UUID,IS_UUID()函数将返回1。 如果参数不是有效的字符串格式UUID,则IS_UUID函数返回0,如果参数为NULL,则IS_UUID()函数返回NULL。

以下是MySQL中有效的字符串格式UUID:

aaaaaaaa-bbbb-cccc-dddd-eeeeeeeeeeeeaaaaaaaabbbbccccddddeeeeeeeeeeee{aaaaaaaa-bbbb-cccc-dddd-eeeeeeeeeeee}

MySQL UUID示例

我们来看一下使用UUID作为主键的例子。

以下语句创建一个名为customers的新表:

USE testdb;CREATE TABLE customers ( id BINARY(16) PRIMARY KEY, name VARCHAR(255));

要将UUID值插入到id列中,可以使用UUID()和UUID_TO_BIN()函数,如下所示:

INSERT INTO customers(id, name)VALUES(UUID_TO_BIN(UUID()),'John Doe'), (UUID_TO_BIN(UUID()),'Will Minsu'), (UUID_TO_BIN(UUID()),'Mary Jane');

要从UUID列查询数据,可以使用BIN_TO_UUID()函数将二进制格式转换为可读取的格式:

SELECT  BIN_TO_UUID(id) id,  nameFROM customers;

在本教程中,您已经了解了MySQL UUID以及如何将其用于主键列。

### 使用 UUID 作为主键的最佳实践 在 MySQL 数据库中使用 UUID 作为主键具有独特的优势,尤其是在分布式环境中。然而,在实现过程中需要注意一些细节以确保最佳性能。 #### 创建表结构 当创建带有 UUID 主键的表格时,建议定义 `CHAR(36)` 类型列并设置为 `NOT NULL` `UNIQUE` 属性。为了简化操作流程,可以通过默认值的方式自动生成新的 UUID 值[^2]: ```sql CREATE TABLE users ( user_uuid CHAR(36) PRIMARY KEY DEFAULT (UUID()), username VARCHAR(50), email VARCHAR(100) ); ``` 上述 SQL 语句会建立一张名为 `users` 的表,其中 `user_uuid` 字段将自动填充由 `UUID()` 函数产生的唯一标识符。 #### 插入数据 向包含 UUID 主键的表内插入记录非常简单,只需省略该字段即可让其自行生成: ```sql INSERT INTO users(username, email) VALUES ('john_doe', 'john@example.com'); ``` 执行这条命令之后,系统将会为新加入的数据行分配独一无二的 `user_uuid` 值。 #### 查询优化 尽管 UUID 提供了全局唯一性的优势,但由于其长度较长且随机分布特性可能导致索引效率降低。因此对于高并发读取场景下的应用来说,可能还需要考虑其他因素来平衡查询速度与存储成本之间的关系[^1]。 #### 处理特殊字符 由于标准格式下生成的 UUID 含有连字符 `-` ,这可能会引起与其他系统的兼容性问题。为了避免这种情况发生,可以在保存之前利用 `REPLACE` 函数移除这些不必要的符号[^4]: ```sql SET @raw_uuid = UUID(); UPDATE some_table SET uuid_field=REPLACE(@raw_uuid,'-',''); ``` 以上代码片段展示了如何先获取原始形式的 UUID 并将其转换成无分隔线版本再更新到指定字段之中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值