这是我能想到的将由UUID()生成的MySQL GUID/UUID转换为binary(16)的最佳方法:
UNHEX(REPLACE(UUID(),'-',''))
然后将其存储在BINARY(16)中。
这种方法有什么影响是我需要知道的吗?
这是我能想到的将由UUID()生成的MySQL GUID/UUID转换为binary(16)的最佳方法:
UNHEX(REPLACE(UUID(),'-',''))
然后将其存储在BINARY(16)中。
这种方法有什么影响是我需要知道的吗?
从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;
影响不大。它会稍微减慢查询速度,但你几乎不会注意到它。
UNIQUEIDENTIFIER
内部存储为 16字节二进制
。
如果你要将二进制加载到客户端并在那里解析它,请注意 位顺序
,它可能有其他字符串表示形式而不是初始的 NEWID()
。
Oracle
的 SYS_GUID()
函数容易出现这个问题,在客户端和服务器上将其转换为字符串会得到不同的结果。