mysql group函数_MySQL函数:group_concat()函数

GROUP_CONCAT(expr)

该函数将非空列值按照分组条件进行合并并最终返回。如果有空值,则返回为空,其完整语法如下:

GROUP_CONCAT([DISTINCT] expr [,expr ...]

[ORDER BY {unsigned_integer | col_name | expr}

[ASC | DESC] [,col_name ...]]

[SEPARATOR str_val])

举例 列1:

SELECT

EMP_ID,

SUM(VALUE1),

SUM(VALUE2),

SUM(VALUE3),

GROUP_CONCAT(REAS_1 SEPARATOR ';'),

GROUP_CONCAT(REAS_2),

GROUP_CONCAT(REAS_3)

FROM

ACT_GP_TEST

GROUP BY

EMP_ID

列2:

SELECT

EMP_ID,

SUM(VALUE1),

SUM(VALUE2),

SUM(VALUE3),

GROUP_CONCAT(REAS_1,REAS_2,REAS_3 SEPARATOR ';')

FROM

ACT_GP_TEST

GROUP BY

EMP_ID

上面列1和列2的区别在于,列2是将字段REAS_1,REAS_2,REAS_3作为一个完整的字段逐条合并。

该函数的最大长度收到环境变量group_concat_max_len的限定,其默认值为1024,当然可以设置的更高。同时有效的最大返回长度也受max_allowed_packet的约束。

在运行是修改group_concat_max_len的语法如下:

SET [GLOBAL | SESSION] group_concat_max_len = val;

返回的结果是二进制还是非二进制字符,取决于函数内取值字段的本身。一般当group_concat_max_len<=512时,为VARCHAR或VARBINARY,当大于该值时为TEXT和BLOB。

0b1331709591d260c1c78e86d0c51c18.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值