簡體   English   中英

將多行合並為一行並組合列SQL

[英]Multiple rows into a single row and combine column SQL

我試圖讓這個視圖查詢兩個表,然后將每個程序ID匯總到一行,其中AttributeNames列中的所有AttributeNames一起

我加入了這兩個表,它提取了適當數量的記錄。
現在,我需要的部分就是將每個ProgramID和一個所有AttributeNames一起放在每個id的AttributeNames列中。

示例:全部在一行中。

ProgramID      | AttributeNames
887            | Studydesign, Control Groups, Primary Outcomes.

這是我需要修改的SQL VIEW的圖像,所以它執行此操作: 在此輸入圖像描述

查詢:

SELECT TOP (100) PERCENT dbo.tblProgramAttributes.ProgramID,
       dbo.tblProgramAttributes.AttributeID AS PAattributeID, 
       dbo.tblAttributes.AttributeID, 
       dbo.tblAttributes.AttributeName
FROM   dbo.tblProgramAttributes INNER JOIN
       dbo.tblAttributes 
ON     dbo.tblProgramAttributes.AttributeID = dbo.tblAttributes.AttributeID
WHERE (dbo.tblProgramAttributes.AttributeID NOT LIKE '%ProgramType%')
ORDER BY dbo.tblProgramAttributes.ProgramID DESC
select ProgramId,
stuff(
(
    select ','+ [attributename]
    from Table1 
    where programid = t.programid for XML path('')

),1,1,'') as AttributeNames
from (select distinct programid 
      from Table1 )t

看看我的sql小提琴

結果

PROGRAMID   ATTRIBUTENAMES
887         Study Design,Control Groups,Primary Outcomes

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM