Computer >> Máy Tính >  >> Lập trình >> MySQL

Truy vấn MySQL để nối tất cả các giá trị trong mỗi hàng dựa trên ID khớp chung

Đầu tiên chúng ta hãy tạo một bảng -

mysql> create table DemoTable
(
   StudentId int,
   StudentFirstName varchar(100),
   StudentLastName varchar(100)
);
Query OK, 0 rows affected (0.54 sec)

Chèn một số bản ghi vào bảng bằng lệnh chèn -

mysql> insert into DemoTable values(1000,'Adam','Smith');
Query OK, 1 row affected (0.17 sec)
mysql> insert into DemoTable values(1000,'John','Doe');
Query OK, 1 row affected (0.12 sec)
mysql> insert into DemoTable values(1000,'David','Miller');
Query OK, 1 row affected (0.12 sec)

Hiển thị tất cả các bản ghi từ bảng bằng câu lệnh select -

mysql> select *from DemoTable;

Điều này sẽ tạo ra kết quả sau -

+-----------+------------------+-----------------+
| StudentId | StudentFirstName | StudentLastName |
+-----------+------------------+-----------------+
|      1000 | Adam             | Smith           |
|      1000 | John             | Doe             |
|      1000 | David            | Miller          |
+-----------+------------------+-----------------+
3 rows in set (0.00 sec)

Sau đây là truy vấn để nối tất cả các giá trị trong mỗi hàng dựa trên ID khớp chung -

mysql> select StudentId,group_concat(StudentFirstName),group_concat(StudentLastName) from DemoTable group by StudentId;

Điều này sẽ tạo ra kết quả sau -

+-----------+--------------------------------+-------------------------------+
| StudentId | group_concat(StudentFirstName) | group_concat(StudentLastName) |
+-----------+--------------------------------+-------------------------------+
|      1000 | Adam,John,David                | Smith,Doe,Miller              |
+-----------+--------------------------------+-------------------------------+
1 row in set (0.00 sec)