SQLSERVER 行传列

以下用法是将多行 某一列的值,按照另外的某一个为基础,合并为以逗号隔开;
table1表字段:operationNameID,resourceID
值:
1,2
1,3
1,4
2,2
2,4

table2表字段:resourceID,resourceName
值:
2,xx2
3,xx3
4,xx4

table3表字段:operationNameID
值:
1
2
3

SELECT table3.operationNameID
,(SELECT name = (
(
stuff(
(
SELECT
‘,’ + CAST (b.resourceName AS VARCHAR)
FROM
table1 a
JOIN table2 b ON a.resourceID = b.resourceID
WHERE a.operationNameID = table3.operationNameID
ORDER BY
a.operationNameID FOR xml path (’’)
),
1, 1, ‘’
)
)
)
) AS resourceName
FROM table3

查询结果:
1 xxx2,xx3,xx4
2 xx2,xx4

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值