博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MySql多行数据合并成一行,将字段中的值拼接在一起
阅读量:5776 次
发布时间:2019-06-18

本文共 761 字,大约阅读时间需要 2 分钟。

  hot3.png

    今天碰到一个问题,由于多表关联查询的关系,返回的数据中有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;

 

哈哈哈哈哈~完美的解决了我的问题,又学了一招

转载于:https://my.oschina.net/meibug/blog/835660

你可能感兴趣的文章
实用的sublime插件集合 – sublime推荐必备插件
查看>>
我的友情链接
查看>>
QPS和TPS解释
查看>>
为什么要使用tomcat+memcache实现session共享而不使用会话保持
查看>>
10个linux 作业控制的bash 脚本示例
查看>>
一个Web报表项目的性能分析和优化实践(六):设置MySQL的最大连接数(max_connections)...
查看>>
RSA加密算法的简单案例
查看>>
XMLHttpRequest对象如何兼容各浏览器使用?
查看>>
perl智能匹配操作符~~
查看>>
ASCII码对照表
查看>>
每天一个linux命令(22):find 命令的参数详解
查看>>
MySQL修改root密码的各种方法整理
查看>>
虚拟机类加载机制
查看>>
【Quick-Cocos2d-x】 捋一捋框架流程
查看>>
Long基本类型的三个静态方法(java)
查看>>
Siege的源码二次开发&操作手册
查看>>
ECstore meta扩展
查看>>
Oracle 学习之RAC(四) 安装Oracle软件
查看>>
Go Interface
查看>>
apache 403 Forbidden
查看>>