0

SQL Server 2008を使用していますが、3つのテーブル、製品、製品タグ、およびタグが必要です。

Products
-----------------
Id | Name

ProductTags 
------------------
Id | ProductId | TagId

Tags
------------------
Id | Name

次のように、最初の列に製品IDを含み、2番目の列に連結された製品に関連付けられたタグの名前を含む結果を返すクエリを作成しようとしています。

productid | Tags
-------------------------------------
1           tag1, tag2, tag3
2           tag2, tag3

私はこれがFOR XML PATH('')何らかの方法で達成できることを知っていますが、私はそれを正しくすることができます。使用FOR XMLは重要ではありません。結果を生み出すどんな解決策でもかまいません。

4

1 に答える 1

2
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
于 2013-03-08T09:13:50.033 に答える