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

Nối một số giá trị cột trong một dòng với MySQL và đặt tiền tố cho một chuỗi cụ thể “MR.” đến mọi chuỗi

Phương thức CONCAT () sẽ được sử dụng để nối “MR” với mọi chuỗi, trong khi GROUP_CONCAT () để nối một số giá trị cột trong một dòng.

Đầu tiên chúng ta hãy xem một ví dụ và tạo một bảng -

mysql> create table DemoTable799(
   UserId int,
   UserName varchar(100),
   UserAge int
);
Query OK, 0 rows affected (0.56 sec)

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

mysql> insert into DemoTable799 values(101,'John',21);
Query OK, 1 row affected (0.18 sec)
mysql> insert into DemoTable799 values(102,'Chris',26);
Query OK, 1 row affected (0.22 sec)
mysql> insert into DemoTable799 values(101,'Robert',23);
Query OK, 1 row affected (0.15 sec)
mysql> insert into DemoTable799 values(103,'David',24);
Query OK, 1 row affected (0.10 sec)
mysql> insert into DemoTable799 values(101,'Mike',29);
Query OK, 1 row affected (0.18 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 DemoTable799;

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

+--------+----------+---------+
| UserId | UserName | UserAge |
+--------+----------+---------+
| 101    | John    | 21       |
| 102    | Chris   | 26       |
| 101    | Robert  | 23       |
| 103    | David   | 24       |
| 101    | Mike    | 29       |
+--------+----------+---------+
5 rows in set (0.00 sec)

Đây là truy vấn để nối các chuỗi -

mysql> select UserId,GROUP_CONCAT(CONCAT('MR.', UserName)) from DemoTable799 group by UserId;

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

+--------+---------------------------------------+
| UserId | GROUP_CONCAT(CONCAT('MR.', UserName)) |
+--------+---------------------------------------+
| 101    | MR.John,MR.Robert,MR.Mike             |
| 102    | MR.Chris                              |
| 103    | MR.David                              |
+--------+---------------------------------------+
3 rows in set (0.00 sec)