Sql server 我在SQL Server PIVOT上遇到了一些问题

Sql server 我在SQL Server PIVOT上遇到了一些问题,sql-server,pivot,max,min,Sql Server,Pivot,Max,Min,我在SQL Server查询中遇到了一些问题。您可以在我的结果中看到,在第1列中,有一条记录“级别1活动”,但实际上有3条记录“级别1活动、级别1活动第二和级别1活动第三”。使用我的命令MIN(activityName),它只显示1 我想知道我们有没有其他方法可以用3条记录来显示这样的数据 SELECT strandName as [Strand Name], scopeName as [Scope Name], FoundationLevel as [Foundatio

我在SQL Server查询中遇到了一些问题。您可以在我的结果中看到,在第1列中,有一条记录“级别1活动”,但实际上有3条记录“级别1活动、级别1活动第二和级别1活动第三”。使用我的命令
MIN(activityName)
,它只显示1

我想知道我们有没有其他方法可以用3条记录来显示这样的数据

SELECT 
   strandName as [Strand Name], 
   scopeName as [Scope Name], 
   FoundationLevel as [Foundation Level], 
   Level1 as [Level 1]
FROM 
    (select 
         st.strandName, s.scopeName, l.levelNo, activityName 
     from 
          strands as st 
     inner join 
          scopes as s on st.id = s.strandID 
     left join 
          activities as a on s.id = a.scopeID 
     left join 
          levels as l on a.levelID = l.id where unitID = 2) up 
PIVOT 
     (min(activityName) FOR levelNo IN (FoundationLevel, Level1)) AS pvt 
ORDER BY 
    scopeName

非常感谢。

您可以使用pivot从记录中创建列
WITH T
     AS (select strandName as [Strand Name] , scopeName as [Scope Name] , FoundationLevel as [Foundation Level] , Level1 as [Level 1]

FROM (select st.strandName, s.scopeName, l.levelNo, activityName from strands as st 

inner join scopes as s on st.id = s.strandID 

left join activities as a on s.id = a.scopeID 

left join levels as l on a.levelID = l.id where unitID = 2) 

SELECT *
FROM   T PIVOT (min(activityName)
FOR levelNo IN (Level 1 activity, Level 1 activity second, Level 1 activity third) ) AS pvt
ORDER  BY OrderID