Đối với điều này, bạn có thể sử dụng GROUP_CONCAT ().
Đầu tiên chúng ta hãy tạo một bảng -
mysql> create table DemoTable764 ( ProductId int, ProductPrice 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 DemoTable764 values(101,10000); Query OK, 1 row affected (0.12 sec) mysql> insert into DemoTable764 values(102,1090); Query OK, 1 row affected (0.14 sec) mysql> insert into DemoTable764 values(103,4000); Query OK, 1 row affected (0.15 sec) mysql> insert into DemoTable764 values(102,3450); Query OK, 1 row affected (0.19 sec) mysql> insert into DemoTable764 values(101,20000); Query OK, 1 row affected (0.14 sec) mysql> insert into DemoTable764 values(104,50000); 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 DemoTable764;
Điều này sẽ tạo ra kết quả sau -
+-----------+--------------+ | ProductId | ProductPrice | +-----------+--------------+ | 101 | 10000 | | 102 | 1090 | | 103 | 4000 | | 102 | 3450 | | 101 | 20000 | | 104 | 50000 | +-----------+--------------+ 6 rows in set (0.00 sec)
Sau đây là truy vấn để nối các cột với các giá trị id trùng lặp tương ứng -
mysql> select ProductId, group_concat(ProductPrice SEPARATOR '/') AS ProductPrice from DemoTable764 group by ProductId;
Điều này sẽ tạo ra kết quả sau -
+-----------+---------------+ | ProductId | ProductPrice | +-----------+---------------+ | 101 | 10000/20000 | | 102 | 1090/3450 | | 103 | 4000 | | 104 | 50000 | +-----------+---------------+ 4 rows in set (0.00 sec)