MAX
描述
MAX 函数返回表达式的最大非 NULL 值。
语法
MAX(<expr>)
参数说明
参数 | 说明 |
---|---|
<expr> | 用于获取值的表达式。支持的类型包括 String、Time、Date、DateTime、IPv4、IPv6、TinyInt、SmallInt、Integer、BigInt、LargeInt、Float、Double、Decimal。 |
返回值
返回与输入表达式相同的数据类型。 如果组内所有记录均为 NULL,则函数返回 NULL。
举例
-- setup
create table t1(
k1 int,
k_string varchar(100),
k_decimal decimal(10, 2)
) distributed by hash (k1) buckets 1
properties ("replication_num"="1");
insert into t1 values
(1, 'apple', 10.01),
(1, 'banana', 20.02),
(2, 'orange', 30.03),
(2, null, null),
(3, null, null);
select k1, max(k_string) from t1 group by k1;
String 类型:对于每个分组,返回最大的字符串值。
+------+---------------+
| k1 | max(k_string) |
+------+---------------+
| 1 | banana |
| 2 | orange |
| 3 | NULL |
+------+---------------+
select k1, max(k_decimal) from t1 group by k1;
Decimal 类型:返回最大的高精度小数值。
+------+----------------+
| k1 | max(k_decimal) |
+------+----------------+
| 1 | 20.02 |
| 2 | 30.03 |
| 3 | NULL |
+------+----------------+
select max(k_string) from t1 where k1 = 3;
当组内所有值都为 NULL 时,返回 NULL。
+---------------+
| max(k_string) |
+---------------+
| NULL |
+---------------+
select max(k_string) from t1;
返回所有数据的最大值。
+---------------+
| max(k_string) |
+---------------+
| orange |
+---------------+