如何使用 GROUP BY 在 MySQL 中连接字符串以及如何为连接设置分隔符?

mysqlmysqli database更新于 2024/3/15 0:05:00

要使用 GROUP BY 在 MySQL 中连接字符串,您需要使用带有 SEPARATOR 参数的 GROUP_CONCAT(),该参数可以是逗号 (‘) 或空格 (‘ ‘) 等。

语法如下:

SELECT yourColumnName1,GROUP_CONCAT(yourColumnName2 SEPARATOR ‘yourValue’) as anyVariableName FROM yourTableName GROUP BY yourColumnName1;

为了理解上述语法,让我们创建一个表。创建表的查询如下:

mysql> create table GroupConcatenateDemo
   -> (
   -> Id int,
   -> Name varchar(20)
   -> );
Query OK, 0 rows affected (0.99 sec)

使用 insert 命令在表中插入一些记录。插入记录的查询如下:

mysql> insert into GroupConcatenateDemo values(10,'Larry');
Query OK, 1 row affected (0.41 sec)
mysql> insert into GroupConcatenateDemo values(11,'Mike');
Query OK, 1 row affected (0.18 sec)
mysql> insert into GroupConcatenateDemo values(12,'John');
Query OK, 1 row affected (0.14 sec)
mysql> insert into GroupConcatenateDemo values(10,'Elon');
Query OK, 1 row affected (0.63 sec)
mysql> insert into GroupConcatenateDemo values(10,'Bob');
Query OK, 1 row affected (0.12 sec)
mysql> insert into GroupConcatenateDemo values(11,'Sam');
Query OK, 1 row affected (0.14 sec)

使用 select 语句显示表中的所有记录。查询如下:

mysql> select *from GroupConcatenateDemo;

输出结果如下:

+------+-------+
| Id   | Name  |
+------+-------+
|   10 | Larry |
|   11 | Mike  |
|   12 | John  |
|   10 | Elon  |
|   10 | Bob   |
|   11 | Sam   |
+------+-------+
6 rows in set (0.00 sec)

这是使用 MySQL 中的 GROUP BY 连接字符串的查询。根据 Id 执行 GROUP BY,并使用 MySQL 中的 GROUP_CONCAT() 函数连接字符串。

查询如下:

mysql> select Id,group_concat(Name SEPARATOR ',') as GroupConcatDemo from GroupConcatenateDemo
   -> group by Id;

输出结果如下:

+------+-----------------+
| Id   | GroupConcatDemo |
+------+-----------------+
|   10 | Larry,Elon,Bob  |
|   11 | Mike,Sam        |
|   12 | John            |
+------+-----------------+
3 rows in set (0.00 sec)

相关文章