这是我能想到的将 UUID() 生成的 MySQL GUID/UUID 转换为二进制 (16) 的最佳方法:
UNHEX(REPLACE(UUID(),'-',''))
然后将其存储在 BINARY(16) 中
这样做有什么我应该知道的含义吗?
最佳答案
影响不大。它会稍微减慢查询速度,但您几乎不会注意到它。
UNIQUEIDENTIFIER
无论如何都会在内部存储为 16 字节二进制
。
如果您要将二进制文件加载到客户端并在那里解析,请注意 bit order
,它可能具有不同于初始 NEWID()
的其他字符串表示.
Oracle
的 SYS_GUID()
函数很容易出现这个问题,将其转换为字符串会在客户端和服务器上产生不同的结果。
关于mysql - 存储 MySQL GUID/UUID,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/547118/