Storing MySQL GUID/UUIDs

后端 未结 2 390
别跟我提以往
别跟我提以往 2020-12-04 12:25

This is the best way I could come up with to convert a MySQL GUID/UUID generated by UUID() to a binary(16):

UNHEX(REPLACE(UUID(),\'-\',\'\'))
2条回答
  •  一整个雨季
    2020-12-04 12:58

    From MySQL 8.0 and above you could use UUID_TO_BIN:

    UUID_TO_BIN(string_uuid), UUID_TO_BIN(string_uuid, swap_flag)

    Converts a string UUID to a binary UUID and returns the result. (The IS_UUID() function description lists the permitted string UUID formats.) The return binary UUID is a VARBINARY(16) value.

    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;
    

    DB-Fiddle.com Demo

提交回复
热议问题