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;
哈哈哈哈哈~完美的解决了我的问题,又学了一招
因为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;
哈哈哈哈哈~完美的解决了我的问题,又学了一招
相关文章推荐
- MySql多行数据合并成一行,将字段中的值拼接在一起
- mysql利用group_concat()合并多行数据到一行
- mysql多行数据合并为一行
- sql查询 ,多行数据合并成一行,并且显示合并后某一列的值拼接结果
- mysql如何将多行数据合并成一行
- mysql把多行数据合并为一行,并且字段名自己定义
- sql查询 ,多行数据合并成一行,并且显示合并后某一列的值拼接结果
- MySql 正则过滤数据 合并表多行的指定字段
- mysql 多行数据合并成一行
- mysql如何将多行数据合并成一行
- mysql将多行数据合并成一行显示
- mysql中将多行数据合并成一行数据
- mysql 根据 某个字段 把一行数据拆成多行
- mysql利用group_concat()合并多行数据到一行
- mysql利用group_concat()合并多行数据到一行
- mysql实现搜索多行数据合并成一行
- mysql 合并多行数据到一行
- mysql利用group_concat()合并多行数据到一行
- 数据库中多行数据合并成一行
- T_SQL 将一列多行数据合并为一行