MySql采用GROUP_CONCAT合并多条数据显示的方法

 更新时间:2014年10月16日 16:02:18   投稿:shichen2014  
这篇文章主要介绍了MySql采用GROUP_CONCAT合并多条数据显示的方法,是MySQL数据库程序设计中常见的实用技巧,需要的朋友可以参考下

本文实例讲述了MySql采用GROUP_CONCAT合并多条数据显示的方法,分享给大家供大家参考。具体实现方法如下:

假设有这样一个需求:
1:班级表:
id class_name
2:学生表:
id name class_id
 
如果我们要查所有的班级以及每个班级下的学生,你一定会想到这样写法:

复制代码 代码如下:
SELECT
banji.*, user.name
FROM `banji`
left join user
on banji.id=user.`class`
where banji.id=2

这样我们得到的结果的个数是和学生人数相同的,而我希望得到的就是一条数据,而这条数据中还要包含所有学生,可以这样写:

复制代码 代码如下:
SELECT
banji.*, GROUP_CONCAT(user.name) as names
FROM `banji`
left join user
on banji.id=user.`class`
where banji.id=2

这样就只得到一条结果了,而结果中包含所有的学生name,

id class_name  names
2  lisi,zhaoliu,liu,小二,xiaoming,小张

还可以自定义分隔符:

复制代码 代码如下:
SELECT
banji.*, GROUP_CONCAT(user.name SEPARATOR "|") as names
FROM `banji`
left join user
on banji.id=user.`class`
where banji.id=2

得到的结果:

id class_name  names
2  lisi|zhaoliu|liu|小二|xiaoming|小张

 二  希望本文所述对大家的MySQL数据库程序设计有所帮助。

相关文章

  • 深入MySQL存储引擎比较的详解

    深入MySQL存储引擎比较的详解

    本篇文章是对MySQL存储引擎的比较进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • Mysql中undo、redo与binlog的区别浅析

    Mysql中undo、redo与binlog的区别浅析

    大家应该都知道日志系统主要有redo log(重做日志)和binlog(归档日志),下面这篇文章主要给大家介绍了关于Mysql中undo、redo与binlog区别的相关资料,需要的朋友可以参考下
    2021-09-09
  • MySQL压力测试方法 如何使用mysqlslap测试MySQL的压力?

    MySQL压力测试方法 如何使用mysqlslap测试MySQL的压力?

    生产服务器用LANMP组合和用LAMP组合有段时间了,总体来说都很稳定。但出现过几次因为MYSQL并发太多而挂掉,一直想对MYSQL做压力测试。刚看到一篇介绍MYSQL压力测试的文章,确实不错,先收藏先吧
    2016-05-05
  • MySQL InnoDB undo log数据结构用法详解

    MySQL InnoDB undo log数据结构用法详解

    InnoDB的undolog用于事务回滚与MVCC,存于共享/独立表空间,包含insert和update两种类型,通过参数配置,由purge线程清理
    2025-07-07
  • 一篇文章带你掌握MySQL索引下推

    一篇文章带你掌握MySQL索引下推

    索引条件下推,也叫索引下推,英文全称Index Condition Pushdown,简称ICP,索引下推是MySQL5.6新添加的特性,用于优化数据的查询,下面这篇文章主要给大家介绍了关于MySQL索引下推的相关资料,需要的朋友可以参考下
    2022-12-12
  • Mysql存储过程中游标的用法实例

    Mysql存储过程中游标的用法实例

    这篇文章主要介绍了Mysql存储过程中游标的用法,以商户关联数据的插入及更新为例分析了MySQL存储过程中游标的使用技巧,需要的朋友可以参考下
    2015-07-07
  • 详解MySQL8.0+常用命令

    详解MySQL8.0+常用命令

    这篇文章主要介绍了MySQL8.0+常用命令及操作命令,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-10-10
  • mysql如何根据汉字首字母排序

    mysql如何根据汉字首字母排序

    这篇文章主要介绍了mysql根据汉字首字母排序sql语句,需要的朋友可以参考下
    2014-03-03
  • MySql如何将查询的出来的字段进行转换

    MySql如何将查询的出来的字段进行转换

    这篇文章主要介绍了MySql如何将查询的出来的字段进行转换,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-06-06
  • CentOs7安装部署Sonar环境的详细过程(JDK1.8+MySql5.7+sonarqube7.8)

    CentOs7安装部署Sonar环境的详细过程(JDK1.8+MySql5.7+sonarqube7.8)

    这篇文章主要介绍了CentOs7安装部署Sonar环境(JDK1.8+MySql5.7+sonarqube7.8),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-06-06

最新评论