存储MySQL GUID/UUID

thr*_*thr 31 mysql binary uuid guid

这是我将UUID()生成的MySQL GUID/UUID转换为二进制(16)的最佳方法:

UNHEX(REPLACE(UUID(),'-',''))
Run Code Online (Sandbox Code Playgroud)

然后将其存储在BINARY(16)

以我应该知道的方式做这件事是否有任何影响?

Qua*_*noi 8

影响不大.它会减慢查询速度,但你几乎不会注意到它.

UNIQUEIDENTIFIER16-byte binary无论如何都存储在内部.

如果要将二进制文件加载到客户端并在那里解析它,请注意bit order,它可能有其他字符串表示形式而不是初始化NEWID().

OracleSYS_GUID()功能很容易出现这个问题,将其转换为字符串会在客户端和服务器上产生不同的结果.

  • 当答案的术语和假设似乎是 MS SQL 独有的,而不是 MySQL 时,我很困惑为什么会接受这一点。 (2认同)

Luk*_*zda 5

从 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;
Run Code Online (Sandbox Code Playgroud)

DB-Fiddle.com 演示

  • 如果使用 UUID_TO_BIN() 调用,则必须使用第二个参数调用 BIN_TO_UUID() ,该参数也为 TRUE。 (2认同)