Heim >Datenbank >MySQL-Tutorial >MySql采用GROUP_CONCAT合并多条数据显示的方法_MySQL

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

WBOY
WBOYOriginal
2016-06-01 13:05:41911Durchsuche

本文实例讲述了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数据库程序设计有所帮助。
Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn