Bạn có thể muốn sử dụng LISTAGG
.
SELECT col_id,
LISTAGG(col_text, '|') WITHIN GROUP (ORDER BY col_text) text
FROM table1
GROUP BY col_id
Đầu ra:
| COL_ID | TEXT |
----------------------------
| 111 | This|a|is|test. |
SQLFiddle
CẬP NHẬT Nếu bạn cần nhận các giá trị văn bản riêng biệt trong danh sách
SELECT col_id,
LISTAGG(col_text, '|')
WITHIN GROUP (ORDER BY col_text) text
FROM
(
SELECT DISTINCT col_id, col_text
FROM table1
)
GROUP BY col_id
SQLFiddle