2015-07-13 73 views
1

我有圖像查詢結果,類似於90日期,所以如何將對象分組並將日期作爲列並計入各自的日期。如何將給定結構轉換爲預期結構?

enter image description here

在此先感謝!

+0

出錯了預期的效果? 201145-01-02? –

+0

您可能正在尋找一個動態數據透視表,或者只是一個正常的數據,如果您有固定的日期數 –

+0

可能dublicate:http://stackoverflow.com/questions/30295640/how-to-return-dynamic-columns- from-grouped-values-in-sql-server-stored-proceduresur/30297102#30297102 – CeOnSql

回答

2

可以使用動態交叉做到這一點:

SQL Fiddle

DECLARE @sql1 VARCHAR(4000) = '' 
DECLARE @sql2 VARCHAR(4000) = '' 
DECLARE @sql3 VARCHAR(4000) = '' 

SELECT @sql1 = 
'SELECT 
    [Object]' + CHAR(10) 

SELECT @sql2 = @sql2 + 
' , MAX(CASE WHEN [Date] = CAST(''' + CONVERT(VARCHAR(8), [Date], 112) + ''' AS DATE) THEN [count] END) AS ' + QUOTENAME([Date]) + CHAR(10) 
FROM(
    SELECT DISTINCT [Date] FROM tbl 
)t 
ORDER BY [Date] 

SELECT @sql3 = 
'FROM tbl 
GROUP BY [Object] 
ORDER BY [Object]' 

PRINT(@sql1 + @sql2 + @sql3) 
EXEC (@sql1 + @sql2 + @sql3) 

結果

| Object | 2015-01-01 | 2015-01-02 | 
|--------|------------|------------| 
|  1 |   10 |   34 | 
|  2 |   20 |   46 | 
|  3 |  130 |   78 | 
|  4 |   40 |   89 | 
|  5 |   55 |   45 | 

這是PRINT命令的輸出:

SELECT 
    [Object] 
    , MAX(CASE WHEN [Date] = CAST('20150101' AS DATE) THEN [count] END) AS [2015-01-01] 
    , MAX(CASE WHEN [Date] = CAST('20150102' AS DATE) THEN [count] END) AS [2015-01-02] 
FROM tbl 
GROUP BY [Object] 
ORDER BY [Object] 
+0

這對我有用。 –

2

您可以使用SQL Server PIVOT關係運算符

DECLARE @SQLQuery AS NVARCHAR(MAX) 
DECLARE @PivotColumns AS NVARCHAR(MAX) 

--Get unique values of pivot column 
SELECT @PivotColumns= COALESCE(@PivotColumns + ',','') + QUOTENAME([Date]) 
FROM (SELECT DISTINCT [Date] FROM [dbo].[PivotExample]) AS PivotExample 



--Create the dynamic query with all the values for 
--pivot column at runtime 
SET @SQLQuery = 
    N'SELECT ObjectId, ' + @PivotColumns + ' 
    FROM [dbo].[PivotExample] 
    PIVOT(SUM(COUNT) 
      FOR [Date] IN (' + @PivotColumns + ')) AS P' 


EXEC sp_executesql @SQLQuery 
相關問題