2

私はSQL 2012に2つのテーブルを持っています: name と prod with structure:

名前:id int increment, name1 nvarchar(50)

製品: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  
4

3 に答える 3

5

残念ながら、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

于 2013-08-20T12:39:57.663 に答える
3

これを試して:

SELECT
G.id,
G.name1,
stuff(
    (select cast(',' as varchar(10)) + U.product
    from prod U
    WHERE U.id_name = G.id
    order by U.product
    for xml path('')
), 1, 1, '') AS prod
FROM name G
ORDER BY G.name1 ASC
于 2013-08-20T12:43:41.110 に答える