HÀM GROUP_CONCAT TRONG MYSQL

Hàm GROUP_CONCAT() trong MySQL được sử dụng để nối nhiều giá trị của các record trong column với nhau thành một chuỗi. Hàm GROUP_CONCAT() rất là hữu dụng cho việc tìm kiếm nhiều records dữ liệu, sau đó trả về một chuỗi.
Mô tả tình huống:
Giả sử chúng ta có bảng Product với dữ liệu như sau:
IdNamePriceDescription
1
Laptop14,000,000ASUS
2
Iphone 4s17,000,000Apple
3
Tivi TOSHIBA6,300,00032 inches
Áp dụng hàm GROUP_CONCAT() như sau:
Trường hợp 1: lấy tất cả record của cột Name và cộng chúng lại với nhau trả về một chuỗi, các record cách nhau bởi dấu phẩy
1
2
SELECT GROUP_CONCAT(NAME)
FROM Product
Kết quả trả về:
1
Laptop,Iphone 4s,Tivi TOSHIBA
Trường hợp 2: giống như trường hợp 1 nhưng các record được sắp sếp theo thứ tự tăng dần
1
2
SELECT GROUP_CONCAT(NAME ORDER BY NAME)
FROM Product
Kết quả trả về:
1
Iphone 4s,Laptop,Tivi TOSHIBA
Trường hợp 3: giống như trường hợp 2 nhưng các record được sắp sếp theo thứ tự giảm dần
1
2
SELECT GROUP_CONCAT(NAME ORDER BY NAME DESC)
FROM Product
Kết quả trả về:
1
Tivi TOSHIBA,Laptop,Iphone 4s
Trường hợp 4: bạn không muốn dùng dấu phẩy (,) giữa các record nữa, bạn có thể thay bất cứ ký tự nào khác
1
2
SELECT GROUP_CONCAT(NAME SEPARATOR '-')
FROM Product
Kết quả trả về:
1
Laptop-Iphone 4s-Tivi TOSHIBA
Ngoài ra, trong trường hợp giá trị các record trùng nhau, bạn có thể dùng DISTINCT để bỏ qua những record trùng nhau, ví dụ như bên dưới:
1
2
SELECT GROUP_CONCAT(DISTINCT NAME)
FROM Product
Như các bạn thấy kết quả dữ liệu của các trường hợp ở trên, kết quả các record của cột Name trả về cách nhau bởi dấu phẩy. Chúng ta nhìn thấy kết quả dính liền lại với nhau. Chúng ta mong muốn đặt một khoảng trắng vào phía sau dấu phẩy để dữ liệu chúng ta rõ ràng dễ đọc hơn. Chúng ta làm như sau:
1
2
SELECT GROUP_CONCAT(NAME SEPARATOR ', ')
FROM Product
Kết quả như sau:
1
Laptop, Iphone 4s, Tivi TOSHIBA
Chú ý: hàm GROUP_CONCAT() bỏ qua những giá trị null.
Như các bạn thấy đấy hàm này rất hữu dụng và rất dễ thực hành.
Góc Kinh Nghiệm chúc các bạn thành công! :razz:

Comments

Popular Posts