这是我能想出的将 UUID() 生成的 MySQL GUID/UUID 转换为二进制 (16) 的最佳方法:
UNHEX(REPLACE(UUID(),'-',''))
然后将其存储在 BINARY(16)
这样做有什么我应该知道的含义吗?
影响不大。它会稍微减慢查询速度,但您几乎不会注意到它。
UNIQUEIDENTIFIER
16-byte binary
无论如何都存储在内部。
如果您要将二进制文件加载到客户端并在那里解析它,请注意bit order
,它可能有其他字符串表示形式而不是初始NEWID()
.
Oracle
的SYS_GUID()
函数很容易出现这个问题,将其转换为字符串会在客户端和服务器上产生不同的结果。
从 MySQL 8.0 及更高版本您可以使用UUID_TO_BIN:
UUID_TO_BIN(string_uuid) , UUID_TO_BIN(string_uuid, swap_flag)
将字符串 UUID 转换为二进制 UUID 并返回结果。(IS_UUID() 函数描述列出了允许的字符串 UUID 格式。)返回的二进制 UUID 是一个 VARBINARY(16) 值。
CREATE TABLE t (id binary(16) PRIMARY KEY);
INSERT INTO t VALUES(UUID_TO_BIN(UUID(), true));
INSERT INTO t VALUES(UUID_TO_BIN(UUID(), true));
INSERT INTO t VALUES(UUID_TO_BIN(UUID(), true));
SELECT *, BIN_TO_UUID(id) FROM t;