[英]Concatenation of rows in T-SQL
我使用SQL Server 2008,我必須有三個表,產品,產品標簽和標簽。
Products
-----------------
Id | Name
ProductTags
------------------
Id | ProductId | TagId
Tags
------------------
Id | Name
我正在嘗試創建查詢,該查詢返回包含第一列中的產品ID的結果以及與第二列中連接的產品關聯的標記的名稱,如下所示:
productid | Tags
-------------------------------------
1 tag1, tag2, tag3
2 tag2, tag3
我知道這可以通過某種方式使用FOR XML PATH('')
來完成,但我能說得對。 使用FOR XML
並不重要。 任何能產生結果的解決方案都可以。
SELECT
c.ID, c.Name ProductName,
STUFF(
(SELECT ',' + b.name
FROM ProductTags a
INNER JOIN Tags b
ON a.TagID = b.ID
WHERE a.ProductID = c.ID
FOR XML PATH (''))
, 1, 1, '') AS TagListList
FROM Products AS c
GROUP BY c.Name, c.ID
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.