1

結合されて一時テーブルに格納されている 2 つのテーブルがあります。

一時テーブルは、次の形式のデータで構成されています。

|ID|Name |Code|  
|1 | 100 |AAAA|
|1 | 100 |AAAB|
|1 | 100 |AAAA|
|2 | 200 |AAAZ|
more...

今、次の形式で結果が必要です。

╔════╦═════════════════════╗
║ ID ║ Name ║   Code       ║
╠════╬═════════════════════╣
║  1 ║ 100  ║   AAAA, AAAB ║
║  2 ║ 200  ║   AAAZ       ║
╚════╩═════════════════════╝

そこで、同様の出力を生成する次のクエリを作成しました。私の質問は、これを達成する他の方法はありますかということです。

SELECT Distinct BSE_ID
    ,BSE_Name
    ,STUFF((
            SELECT ', ' + CAST(EBS_ExternalCode AS VARCHAR(100)) [text()]
            FROM #tmpBkgSvc
            WHERE BSE_ID = T.BSE_ID
            FOR XML PATH('')
                ,TYPE
            ).value('.', 'NVARCHAR(MAX)'), 1, 2, ' ') EBS_ExternalCode
FROM #tmpBkgSvc T
4

3 に答える 3

1

これを試して

Create function Fun
(
    @id int, @name varchar(100)
)
returns varchar(max)
as
begin 

       Declare @code varchar(max)
       Select @code = isnull(@code+',','')+s.code
       from (Select distinct code 
              from table 
               where name = @name and id = @id) s
       Return @code
end

Select id,name,[dbo].Fun(id,Name) 'Code' from table group by id,name
于 2014-06-30T09:31:19.723 に答える
0

このようにしてみて、Use group By In the Code column

SELECT Distinct ID, Name
    ,STUFF((
            SELECT ', ' + CAST(Code AS VARCHAR(100)) [text()]
            FROM DataTable
            WHERE ID = T.ID Group By Code //group by does the magic here
            FOR XML PATH('')
                ,TYPE
            ).value('.', 'NVARCHAR(MAX)'), 1, 2, ' ') Code 
FROM DataTable T
于 2014-06-30T09:29:03.827 に答える