UUID Data Type
The UUID data type was added in a MariaDB 10.7.0 preview.
Syntax
UUID
Description
The UUID
data type is intended for the storage of 128-bit UUID (Universally Unique Identifier) data. See the UUID function page for more details on UUIDs themselves.
Retrieval
Data retrieved by this data type is in the string representation defined in RFC4122.
Casting
String literals of hexadecimal characters and CHAR/VARCHAR/TEXT can be cast to the UUID data type. Likewise hexadecimal literals, binary-literals, and BINARY/VARBINARY/BLOB types can also be cast to UUID.
The data type will not accept a short UUID generated with the UUID_SHORT function, but will accept a value without the -
character generated by the SYS_GUID function (or inserted directly). Hyphens can be partially omitted as well, or included after any group of two digits.
The type does not accept UUIDs in braces, permitted by some implementations.
Examples
CREATE TABLE t1 (id UUID);
Directly Inserting via string literals:
INSERT INTO t1 VALUES('123e4567-e89b-12d3-a456-426655440000');
Directly Inserting via hexadecimal literals:
INSERT INTO t1 VALUES (x'fffffffffffffffffffffffffffffffe');
Generating and inserting via the UUID function.
INSERT INTO t1 VALUES (UUID());
Retrieval:
SELECT * FROM t1; +--------------------------------------+ | id | +--------------------------------------+ | 123e4567-e89b-12d3-a456-426655440000 | | ffffffff-ffff-ffff-ffff-fffffffffffe | | 93aac041-1a14-11ec-ab4e-f859713e4be4 | +--------------------------------------+
The UUID_SHORT function does not generate valid full-length UUID:
INSERT INTO t1 VALUES (UUID_SHORT()); ERROR 1292 (22007): Incorrect uuid value: '99440417627439104' for column `test`.`t1`.`id` at row 1
Accepting a value without the -
character, either directly or generated by the SYS_GUID function:
INSERT INTO t1 VALUES (SYS_GUID()); SELECT * FROM t1; +--------------------------------------+ | id | +--------------------------------------+ | 123e4567-e89b-12d3-a456-426655440000 | | ffffffff-ffff-ffff-ffff-fffffffffffe | | 93aac041-1a14-11ec-ab4e-f859713e4be4 | | ea0368d3-1a14-11ec-ab4e-f859713e4be4 | +--------------------------------------+ SELECT SYS_GUID(); +----------------------------------+ | SYS_GUID() | +----------------------------------+ | ff5b6bcc1a1411ecab4ef859713e4be4 | +----------------------------------+ INSERT INTO t1 VALUES ('ff5b6bcc1a1411ecab4ef859713e4be4'); SELECT * FROM t1; +--------------------------------------+ | id | +--------------------------------------+ | 123e4567-e89b-12d3-a456-426655440000 | | ffffffff-ffff-ffff-ffff-fffffffffffe | | 93aac041-1a14-11ec-ab4e-f859713e4be4 | | ea0368d3-1a14-11ec-ab4e-f859713e4be4 | | ff5b6bcc-1a14-11ec-ab4e-f859713e4be4 | +--------------------------------------+
Valid and invalid hyphen and brace usage:
TRUNCATE t1; INSERT INTO t1 VALUES ('f8aa-ed66-1a1b-11ec-ab4e-f859-713e-4be4'); INSERT INTO t1 VALUES ('1b80667f1a1c-11ecab4ef859713e4be4'); INSERT INTO t1 VALUES ('2fd6c945-1a-1c-11ec-ab4e-f859713e4be4'); INSERT INTO t1 VALUES ('49-c9-f9-59-1a-1c-11ec-ab4e-f859713e4be4'); INSERT INTO t1 VALUES ('57-96-da-c1-1a-1c-11-ec-ab-4e-f8-59-71-3e-4b-e4'); INSERT INTO t1 VALUES ('6-eb74f8f-1a1c-11ec-ab4e-f859713e4be4'); ERROR 1292 (22007): Incorrect uuid value: '6-eb74f8f-1a1c-11ec-ab4e-f859713e4be4' for column `test`.`t1`.`id` at row 1 INSERT INTO t1 VALUES ('{29bad136-1a1d-11ec-ab4e-f859713e4be4}'); ERROR 1292 (22007): Incorrect uuid value: '{29bad136-1a1d-11ec-ab4e-f859713e4be4}' for column `test`.`t1`.`id` at row 1 SELECT * FROM t1; +--------------------------------------+ | id | +--------------------------------------+ | f8aaed66-1a1b-11ec-ab4e-f859713e4be4 | | 1b80667f-1a1c-11ec-ab4e-f859713e4be4 | | 2fd6c945-1a1c-11ec-ab4e-f859713e4be4 | | 49c9f959-1a1c-11ec-ab4e-f859713e4be4 | | 5796dac1-1a1c-11ec-ab4e-f859713e4be4 | +--------------------------------------+
See Also
- 10.7 preview feature: UUID Data Type (mariadb.org blog post)
- UUID function
- UUID_SHORT function
-
SYS_GUID - UUID without the
-
character for Oracle compatibility
© 2021 MariaDB
Licensed under the Creative Commons Attribution 3.0 Unported License and the GNU Free Documentation License.
https://mariadb.com/kb/en/uuid-data-type/