一、PIVOT實(shí)例
1. 建表
建立一個(gè)銷售情況表,其中,year字段表示年份,quarter字段表示季度,amount字段表示銷售額。quarter字段分別用Q1, Q2, Q3, Q4表示一、二、三、四季度。
CREATE TABLE SalesByQuarter
(? ? year INT,? ? -- 年份
quarter CHAR(2),? -- 季度
amount MONEY? -- 總額
)
2. 填入表數(shù)據(jù)
使用如下程序填入表數(shù)據(jù)。
SET NOCOUNT ON
DECLARE @index INT
DECLARE @q INT
SET @index = 0
DECLARE @year INT
while (@index < 30)
BEGIN
SET @year = 2005 + (@index % 4)
SET @q = (CAST((RAND() * 500) AS INT) % 4) + 1
INSERT INTO SalesByQuarter VALUES (@year, 'Q' + CAST(@q AS CHAR(1)), RAND() * 10000.00)
SET @index = @index + 1
END
3、如果我們要比較每年中各季度的銷售狀況,要怎么辦呢?有以下兩種方法:
(1)、使用傳統(tǒng)Select的CASE語句查詢
在SQL Server以前的版本里,將行級(jí)數(shù)據(jù)轉(zhuǎn)換為列級(jí)數(shù)據(jù)就要用到一系列CASE語句和聚合查詢。雖然這種方式讓開發(fā)人員具有了對(duì)所返回?cái)?shù)據(jù)進(jìn)行高度控制的能力,但是編寫出這些查詢是一件很麻煩的事情。
SELECT year as 年份
, sum (case when quarter = 'Q1' then amount else 0 end) 一季度
, sum (case when quarter = 'Q2' then amount else 0 end) 二季度
, sum (case when quarter = 'Q3' then amount else 0 end) 三季度
, sum (case when quarter = 'Q4' then amount else 0 end) 四季度
FROM SalesByQuarter GROUP BY year ORDER BY year DESC
(2)、使用PIVOT
由于SQL Server 2005有了新的PIVOT運(yùn)算符,就不再需要CASE語句和GROUP BY語句了。(每個(gè)PIVOT查詢都涉及某種類型的聚合,因此你可以忽略GROUP BY語句。)PIVOT運(yùn)算符讓我們能夠利用CASE語句查詢實(shí)現(xiàn)相同的功能,但是你可以用更少的代碼就實(shí)現(xiàn),而且看起來更漂亮。
select * from (SELECT year, QUARTER, AMOUNT FROM SalesByQuarter)?
PIVOT (count (AMOUNT) FOR QUARTER IN ('Q1' as Q1, 'Q2' as Q2, 'Q3' as Q3, 'Q4' as Q4) ) GROUP BY YEAR;