Thật không may, không có cách nào dễ dàng để làm điều đó trong SQL Server. Các giải pháp đã biết là:
- thủ thuật xml (xem bên dưới);
- sử dụng biến để tích lũy dữ liệu (không hoạt động với nhiều hàng nhóm, chỉ với con trỏ);
- tổng hợp CLR tùy chỉnh;
đây là xml:
select
n.name1,
stuff(
(
select ', ' + p.product
from prod as p
where p.id_name = n.id
for xml path(''), type).value('.', 'nvarchar(max)')
, 1, 2, '') as products
from name as n
đây là biến:
declare @product nvarchar(max), @id int
select @id = 1
select @product = isnull(@product + ', ', '') + product
from prod
where id_name = @id
select name1, @product as products
from name
where id = @id