您的位置:首页 > 数据库 > MySQL

MySql多行数据合并成一行,将字段中的值拼接在一起

2017-02-10 00:00 671 查看
今天碰到一个问题,由于多表关联查询的关系,返回的数据中有2条id相同但是其中一个字段(职称)不同的结果,这个字段还必须展示并且以此字段查询。

因为id相同所以使用group by id就可以了,但是分组之后的数据只有一个,无法显示此id的另一个职称,这TM就尴尬了~,所谓功夫不负有心人,我在网上找到了MySql的group_concat()函数,

group_concat函数的语法及介绍:

GROUP_CONCAT([DISTINCT] expr [,expr ...]
[ORDER BY {unsigned_integer | col_name | formula} [ASC | DESC] [,col ...]]
[SEPARATOR str_val])
在 MySQL 中,你可以得到表达式结合体的连结值。通过使用 DISTINCT 可以排除重复值。如果希望对结果中的值进行排序,可以使用 ORDER BY 子句。
SEPARATOR 是一个字符串值,它被用于插入到结果值中。缺省为一个逗号 (","),可以通过指定 SEPARATOR "" 完全地移除这个分隔符。
可以通过变量 group_concat_max_len 设置一个最大的长度。在运行时执行的句法如下: SET [SESSION | GLOBAL] group_concat_max_len = unsigned_integer;
如果最大长度被设置,结果值被剪切到这个最大长度。如果分组的字符过长,可以对系统参数进行设置:SET @@global.group_concat_max_len=40000;

哈哈哈哈哈~完美的解决了我的问题,又学了一招
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息