其他函数
TiDB 支持使用 MySQL 8.0 中提供的大部分其他函数。
支持的函数
| 函数名 | 功能描述 | 
|---|---|
ANY_VALUE() | 在 ONLY_FULL_GROUP_BY 模式下,防止带有 GROUP BY 的语句报错 | 
BIN_TO_UUID() | 将通用唯一识别码 (UUID) 从二进制格式转换为文本格式 | 
DEFAULT() | 返回表的某一列的默认值 | 
GROUPING() | GROUP BY 操作的修饰符 | 
INET_ATON() | 将 IP 地址转换为数值 | 
INET_NTOA() | 将数值转换为 IP 地址 | 
INET6_ATON() | 将 IPv6 地址转换为数值 | 
INET6_NTOA() | 将数值转换为 IPv6 地址 | 
IS_IPV4() | 判断参数是否为 IPv4 地址 | 
IS_IPV4_COMPAT() | 判断参数是否为兼容 IPv4 的地址 | 
IS_IPV4_MAPPED() | 判断参数是否为 IPv4 映射的地址 | 
IS_IPV6() | 判断参数是否为 IPv6 地址 | 
IS_UUID() | 判断参数是否为 UUID | 
NAME_CONST() | 可以用于重命名列名 | 
SLEEP() | 让语句暂停执行几秒时间 | 
UUID() | 返回一个通用唯一识别码 (UUID) | 
UUID_TO_BIN() | 将 UUID 从文本格式转换为二进制格式 | 
VALUES() | 定义 INSERT 语句使用的值 | 
ANY_VALUE()
ANY_VALUE() 函数可以从一组值中返回其中任意一个值。通常,该函数用于需要在 SELECT 语句中包含非聚合列以及 GROUP BY 子句的场景中。
CREATE TABLE fruits (id INT PRIMARY KEY, name VARCHAR(255));
Query OK, 0 rows affected (0.14 sec)
INSERT INTO fruits VALUES (1,'apple'),(2,'apple'),(3,'pear'),(4,'banana'),(5, 'pineapple');
Query OK, 5 rows affected (0.01 sec)
Records: 5  Duplicates: 0  Warnings: 0
SELECT id,name FROM fruits GROUP BY name;
ERROR 1055 (42000): Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'test.fruits.id' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by
SELECT ANY_VALUE(id),GROUP_CONCAT(id),name FROM fruits GROUP BY name;
+---------------+------------------+-----------+
| ANY_VALUE(id) | GROUP_CONCAT(id) | name      |
+---------------+------------------+-----------+
|             1 | 1,2              | apple     |
|             3 | 3                | pear      |
|             4 | 4                | banana    |
|             5 | 5                | pineapple |
+---------------+------------------+-----------+
4 rows in set (0.00 sec)
在以上示例中,执行了第一条 SELECT 语句后,TiDB 返回了一条错误,这是因为 id 列是非聚合列且未包含在 GROUP BY 子句中。为了解决此问题,第二个 SELECT 查询使用了 ANY_VALUE() 从每个组中获取任意值,并使用了 GROUP_CONCAT() 将每个组中 id 列的所有值拼接成一个字符串。通过这种方法,你可以获取每个组中的一个值以及该组的所有值,而无需改变非聚合列的 SQL 模式。
BIN_TO_UUID()
BIN_TO_UUID() 和 UUID_TO_BIN() 用于在文本格式 UUID 和二进制格式 UUID 之间进行转换。这两个函数都可以接受两个参数。
- 第一个参数用于指定要转换的值。
 - 第二个参数(可选)用于控制二进制格式中字段的排序。
 
SET @a := UUID();
Query OK, 0 rows affected (0.00 sec)
SELECT @a;
+--------------------------------------+
| @a                                   |
+--------------------------------------+
| 9a17b457-eb6d-11ee-bacf-5405db7aad56 |
+--------------------------------------+
1 row in set (0.00 sec)
SELECT UUID_TO_BIN(@a);
+------------------------------------+
| UUID_TO_BIN(@a)                    |
+------------------------------------+
| 0x9A17B457EB6D11EEBACF5405DB7AAD56 |
+------------------------------------+
1 row in set (0.00 sec)
SELECT BIN_TO_UUID(0x9A17B457EB6D11EEBACF5405DB7AAD56);
+-------------------------------------------------+
| BIN_TO_UUID(0x9A17B457EB6D11EEBACF5405DB7AAD56) |
+-------------------------------------------------+
| 9a17b457-eb6d-11ee-bacf-5405db7aad56            |
+-------------------------------------------------+
1 row in set (0.00 sec)
SELECT UUID_TO_BIN(@a, 1);
+----------------------------------------+
| UUID_TO_BIN(@a, 1)                     |
+----------------------------------------+
| 0x11EEEB6D9A17B457BACF5405DB7AAD56     |
+----------------------------------------+
1 row in set (0.00 sec)
SELECT BIN_TO_UUID(0x11EEEB6D9A17B457BACF5405DB7AAD56, 1);
+----------------------------------------------------+
| BIN_TO_UUID(0x11EEEB6D9A17B457BACF5405DB7AAD56, 1) |
+----------------------------------------------------+
| 9a17b457-eb6d-11ee-bacf-5405db7aad56               |
+----------------------------------------------------+
1 row in set (0.00 sec)
DEFAULT()
DEFAULT() 函数用于获取列的默认值。
CREATE TABLE t1 (id INT PRIMARY KEY, c1 INT DEFAULT 5);
Query OK, 0 rows affected (0.15 sec)
INSERT INTO t1 VALUES (1, 1);
Query OK, 1 row affected (0.01 sec)
UPDATE t1 SET c1=DEFAULT(c1)+3;
Query OK, 1 row affected (0.02 sec)
Rows matched: 1  Changed: 1  Warnings: 0
TABLE t1;
+----+------+
| id | c1   |
+----+------+
|  1 |    8 |
+----+------+
1 row in set (0.00 sec)
在以上示例中,UPDATE 语句将 c1 列的值设置为列的默认值(即 5)加 3,从而得到一个新值 8。
GROUPING()
参见 GROUP BY 修饰符。
INET_ATON()
INET_ATON() 函数用于将点分十进制形式表示的 IPv4 地址转换为可有效存储的二进制形式。
SELECT INET_ATON('127.0.0.1');
+------------------------+
| INET_ATON('127.0.0.1') |
+------------------------+
|             2130706433 |
+------------------------+
1 row in set (0.00 sec)
INET_NTOA()
INET_NTOA() 函数用于将二进制 IPv4 地址转换为点分十进制表示形式。
SELECT INET_NTOA(2130706433);
+-----------------------+
| INET_NTOA(2130706433) |
+-----------------------+
| 127.0.0.1             |
+-----------------------+
1 row in set (0.00 sec)
INET6_ATON()
INET6_ATON() 函数的功能类似于 INET_ATON(),但 INET6_ATON() 还可以处理 IPv6 地址。
SELECT INET6_ATON('::1');
+--------------------------------------+
| INET6_ATON('::1')                    |
+--------------------------------------+
| 0x00000000000000000000000000000001   |
+--------------------------------------+
1 row in set (0.00 sec)
INET6_NTOA()
INET6_NTOA() 函数的功能类似于 INET_NTOA(),但 INET6_NTOA() 还可以处理 IPv6 地址。
SELECT INET6_NTOA(0x00000000000000000000000000000001);
+------------------------------------------------+
| INET6_NTOA(0x00000000000000000000000000000001) |
+------------------------------------------------+
| ::1                                            |
+------------------------------------------------+
1 row in set (0.00 sec)
IS_IPV4()
IS_IPV4() 函数用于判断输入的参数是否为 IPv4 地址。
SELECT IS_IPV4('127.0.0.1');
+----------------------+
| IS_IPV4('127.0.0.1') |
+----------------------+
|                    1 |
+----------------------+
1 row in set (0.00 sec)
SELECT IS_IPV4('300.0.0.1');
+----------------------+
| IS_IPV4('300.0.0.1') |
+----------------------+
|                    0 |
+----------------------+
1 row in set (0.00 sec)
IS_IPV4_COMPAT()
IS_IPV4_COMPAT() 函数用于判断输入的参数是否为兼容 IPv4 的地址。
SELECT IS_IPV4_COMPAT(INET6_ATON('::127.0.0.1'));
+-------------------------------------------+
| IS_IPV4_COMPAT(INET6_ATON('::127.0.0.1')) |
+-------------------------------------------+
|                                         1 |
+-------------------------------------------+
1 row in set (0.00 sec)
IS_IPV4_MAPPED()
IS_IPV4_MAPPED() 函数用于判断输入的参数是否为 IPv4 映射的地址。
SELECT IS_IPV4_MAPPED(INET6_ATON('::ffff:127.0.0.1'));
+------------------------------------------------+
| IS_IPV4_MAPPED(INET6_ATON('::ffff:127.0.0.1')) |
+------------------------------------------------+
|                                              1 |
+------------------------------------------------+
1 row in set (0.00 sec)
IS_IPV6()
IS_IPV6() 函数用于判断输入的参数是否为 IPv6 地址。
SELECT IS_IPV6('::1');
+----------------+
| IS_IPV6('::1') |
+----------------+
|              1 |
+----------------+
1 row in set (0.00 sec)
IS_UUID()
IS_UUID() 函数用于判断输入的参数是否为 UUID。
SELECT IS_UUID('eb48c08c-eb71-11ee-bacf-5405db7aad56');
+-------------------------------------------------+
| IS_UUID('eb48c08c-eb71-11ee-bacf-5405db7aad56') |
+-------------------------------------------------+
|                                               1 |
+-------------------------------------------------+
1 row in set (0.00 sec)
NAME_CONST()
函数 NAME_CONST() 用于命名列。建议使用列别名功能代替。
SELECT NAME_CONST('column name', 'value') UNION ALL SELECT 'another value';
+---------------+
| column name   |
+---------------+
| another value |
| value         |
+---------------+
2 rows in set (0.00 sec)
上面这条语句使用了 NAME_CONST(),下面这条语句使用了列别名的方式(推荐)。
SELECT 'value' AS 'column name' UNION ALL SELECT 'another value';
+---------------+
| column name   |
+---------------+
| value         |
| another value |
+---------------+
2 rows in set (0.00 sec)
SLEEP()
SLEEP() 函数用于将查询暂停执行几秒。
SELECT SLEEP(1.5);
+------------+
| SLEEP(1.5) |
+------------+
|          0 |
+------------+
1 row in set (1.50 sec)
UUID()
UUID() 函数用于返回通用唯一标识符 (UUID) version 1。UUID 的定义可参考 RFC 4122。
SELECT UUID();
+--------------------------------------+
| UUID()                               |
+--------------------------------------+
| cb4d5ae6-eb6b-11ee-bacf-5405db7aad56 |
+--------------------------------------+
1 row in set (0.00 sec)
另请参阅 UUID 最佳实践。
UUID_TO_BIN
参见 BIN_TO_UUID()。
VALUES()
VALUES(col_name) 函数用于在 INSERT 语句的 ON DUPLICATE KEY UPDATE 子句中引用特定列的值。
CREATE TABLE t1 (id INT PRIMARY KEY, c1 INT);
Query OK, 0 rows affected (0.17 sec)
INSERT INTO t1 VALUES (1,51),(2,52),(3,53),(4,54),(5,55);
Query OK, 5 rows affected (0.01 sec)
Records: 5  Duplicates: 0  Warnings: 0
INSERT INTO t1 VALUES(2,22),(4,44) ON DUPLICATE KEY UPDATE c1=VALUES(id)+100;
Query OK, 4 rows affected (0.01 sec)
Records: 2  Duplicates: 2  Warnings: 0
TABLE t1;
+----+------+
| id | c1   |
+----+------+
|  1 |   51 |
|  2 |  102 |
|  3 |   53 |
|  4 |  104 |
|  5 |   55 |
+----+------+
5 rows in set (0.00 sec)
不支持的函数
| 函数名 | 功能描述 | 
|---|---|
UUID_SHORT() | 基于特定假设提供唯一的 UUID,目前这些假设在 TiDB 中不存在,详见 TiDB #4620 |