MAX_BY 函数
功能描述
MAX_BY 函数用于从一组数据中返回与 expr2 表达式的最大值相关联的 expr1 表达式的值。该函数在处理成对的数据时非常有用,可以帮助您快速找到与最大值相对应的数据项。
参数说明
- expr1:任何数据类型的表达式。
- expr2:可比较的数据类型表达式,包括数值类型(如 tinyint、smallint、int、bigint、float、double、decimal),时间类型(如 date、timestamp)以及字符串类型(如 char、varchar、string、binary)。
返回结果
返回与 expr2 表达式的最大值相关联的 expr1 表达式的值。结果类型与 expr1 的类型匹配。如果 expr2 中的所有值均为 null,则返回 null。
使用示例
-
从一组字符串和整数数据中找到与最大整数值相关联的字符串:
SELECT max_by(str, num) FROM VALUES ('apple', 1), ('banana', 3), ('cherry', 2) AS tab(str, num);
+------------------+
| max_by(str, num) |
+------------------+
| banana |
+------------------+
-
从一组日期和字符串数据中找到与最晚日期相关联的字符串:
SELECT max_by(str, date) FROM VALUES ('event1', '2022-01-01'), ('event2', '2022-02-01'), ('event3', '2022-01-15') AS tab(str, date);
+---------------------+
| max_by(str, `date`) |
+---------------------+
| event2 |
+---------------------+
-
从一组员工姓名和工资数据中找到与最高工资相关联的员工姓名:
SELECT max_by(name, salary) FROM VALUES ('Alice', 5000), ('Bob', 6000), ('Charlie', 4500) AS tab(name, salary);
+----------------------+
| max_by(name, salary) |
+----------------------+
| Bob |
+----------------------+