我在 sql 2012 中有两个表:名称和产品,其结构:
name: id int increment, name1 nvarchar(50)
prod: id int increment, products nvarchar(50), id_name int
表的值为:
姓名表:
Id name1
1 pop
2 andi
产品表:
Id products id_name
1 coke 1
2 pizza 1
3 orange 2
我已经完成了这个查询:
select name.name1, prod.product, prod.id_name
from name
join prod on name.id=prod.id_name
我怎样才能获得这个结果:
pop ->coke, pizza
andi->orange
不幸的是,在 SQL Server 中没有简单的方法可以做到这一点。已知的解决方案有:
- xml 技巧(见下文);
- 使用变量来累积数据(不适用于多组行,仅适用于游标);
- 自定义 CLR 聚合;
这是 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
sql fiddle demo
这是变量:
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
sql fiddle demo
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)