亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

一個(gè)簡(jiǎn)單的SQL 行列轉(zhuǎn)換語(yǔ)句

 更新時(shí)間:2009年08月29日 16:35:36   作者:  
在數(shù)據(jù)庫(kù)開(kāi)發(fā)中經(jīng)常會(huì)遇到行列轉(zhuǎn)換的問(wèn)題,比如下面的問(wèn)題,部門(mén),員工和員工類(lèi)型三張表,我們要統(tǒng)計(jì)類(lèi)似這樣的列表
一個(gè)簡(jiǎn)單的SQL 行列轉(zhuǎn)換
Author: eaglet
在數(shù)據(jù)庫(kù)開(kāi)發(fā)中經(jīng)常會(huì)遇到行列轉(zhuǎn)換的問(wèn)題,比如下面的問(wèn)題,部門(mén),員工和員工類(lèi)型三張表,我們要統(tǒng)計(jì)類(lèi)似這樣的列表
部門(mén)編號(hào) 部門(mén)名稱(chēng) 合計(jì) 正式員工 臨時(shí)員工 辭退員工
1 A 30 20 10 1
這種問(wèn)題咋一看摸不著頭緒,不過(guò)把思路理順后再看,本質(zhì)就是一個(gè)行列轉(zhuǎn)換的問(wèn)題。下面我結(jié)合這個(gè)簡(jiǎn)單的例子來(lái)實(shí)現(xiàn)行列轉(zhuǎn)換。
下面3張表
復(fù)制代碼 代碼如下:

if exists ( select * from sysobjects where id = object_id ( ' EmployeeType ' ) and type = ' u ' )
drop table EmployeeType
GO
if exists ( select * from sysobjects where id = object_id ( ' Employee ' ) and type = ' u ' )
drop table Employee
GO
if exists ( select * from sysobjects where id = object_id ( ' Department ' ) and type = ' u ' )
drop table Department
GO
create table Department
(
Id int primary key ,
Department varchar ( 10 )
)
create table Employee
(
EmployeeId int primary key ,
DepartmentId int Foreign Key (DepartmentId) References Department(Id) , -- DepartmentId ,
EmployeeName varchar ( 10 )
)
create table EmployeeType
(
EmployeeId int Foreign Key (EmployeeId) References Employee(EmployeeId) , -- EmployeeId ,
EmployeeType varchar ( 10 )
)

描述部門(mén),員工和員工類(lèi)型之間的關(guān)系。
插入測(cè)試數(shù)據(jù)
復(fù)制代碼 代碼如下:

insert Department values ( 1 , ' A ' );
insert Department values ( 2 , ' B ' );
insert Employee values ( 1 , 1 , ' Bob ' );
insert Employee values ( 2 , 1 , ' John ' );
insert Employee values ( 3 , 1 , ' May ' );
insert Employee values ( 4 , 2 , ' Tom ' );
insert Employee values ( 5 , 2 , ' Mark ' );
insert Employee values ( 6 , 2 , ' Ken ' );
insert EmployeeType values ( 1 , ' 正式 ' );
insert EmployeeType values ( 2 , ' 臨時(shí) ' );
insert EmployeeType values ( 3 , ' 正式 ' );
insert EmployeeType values ( 4 , ' 正式 ' );
insert EmployeeType values ( 5 , ' 辭退 ' );
insert EmployeeType values ( 6 , ' 正式 ' );

看一下部門(mén)、員工和員工類(lèi)型的列表
Department EmployeeName EmployeeType
---------- ------------ ------------
A Bob 正式
A John 臨時(shí)
A May 正式
B Tom 正式
B Mark 辭退
B Ken 正式
現(xiàn)在我們需要輸出這樣一個(gè)列表
部門(mén)編號(hào) 部門(mén)名稱(chēng) 合計(jì) 正式員工 臨時(shí)員工 辭退員工
這個(gè)問(wèn)題我的思路是首先統(tǒng)計(jì)每個(gè)部門(mén)的員工類(lèi)型總數(shù)
這個(gè)比較簡(jiǎn)單,我把它做成一個(gè)視圖
復(fù)制代碼 代碼如下:

if exists ( select * from sysobjects where id = object_id ( ' VDepartmentEmployeeType ' ) and type = ' v ' )
drop view VDepartmentEmployeeType
GO
create view VDepartmentEmployeeType
as
select Department.Id, Department.Department, EmployeeType.EmployeeType, count (EmployeeType.EmployeeType) Cnt
from Department, Employee, EmployeeType where
Department.Id = Employee.DepartmentId and Employee.EmployeeId = EmployeeType.EmployeeId
group by Department.Id, Department.Department, EmployeeType.EmployeeType
GO

現(xiàn)在 select * from VDepartmentEmployeeType
Id Department EmployeeType Cnt
----------- ---------- ------------ -----------
2 B 辭退 1
1 A 臨時(shí) 1
1 A 正式 2
2 B 正式 2
有了這個(gè)結(jié)果,我們?cè)偻ㄟ^(guò)行列轉(zhuǎn)換,就可以實(shí)現(xiàn)要求的輸出了
行列轉(zhuǎn)換采用 case 分支語(yǔ)句來(lái)實(shí)現(xiàn),如下:
復(fù)制代碼 代碼如下:

select Id as ' 部門(mén)編號(hào) ' , Department as ' 部門(mén)名稱(chēng) ' ,
[ 正式 ] = Sum ( case when EmployeeType = ' 正式 ' then Cnt else 0 end ),
[ 臨時(shí) ] = Sum ( case when EmployeeType = ' 臨時(shí) ' then Cnt else 0 end ),
[ 辭退 ] = Sum ( case when EmployeeType = ' 辭退 ' then Cnt else 0 end ),
[ 合計(jì) ] = Sum ( case when EmployeeType <> '' then Cnt else 0 end )
from VDepartmentEmployeeType
GROUP BY Id, Department

看一下結(jié)果
部門(mén)編號(hào) 部門(mén)名稱(chēng) 正式 臨時(shí) 辭退 合計(jì)
----------- ---------- ----------- ----------- ----------- -----------
1 A 2 1 0 3
2 B 2 0 1 3
現(xiàn)在還有一個(gè)問(wèn)題,如果員工類(lèi)型不可以應(yīng)編碼怎么辦?也就是說(shuō)我們?cè)趯?xiě)程序的時(shí)候并不知道有哪些員工類(lèi)型。這確實(shí)是一個(gè)
比較棘手的問(wèn)題,不過(guò)不是不能解決,我們可以通過(guò)拼接SQL的方式來(lái)解決這個(gè)問(wèn)題??聪旅娲a
復(fù)制代碼 代碼如下:

DECLARE
@s VARCHAR ( max )
SELECT @s = isnull ( @s + ' , ' , '' ) + ' [ ' + ltrim (EmployeeType) + ' ] = ' +
' Sum(case when EmployeeType = ''' +
EmployeeType + ''' then Cnt else 0 end) '
FROM ( SELECT DISTINCT EmployeeType FROM VDepartmentEmployeeType ) temp
EXEC ( ' select Id as 部門(mén)編號(hào), Department as 部門(mén)名稱(chēng), ' + @s +
' ,[合計(jì)]= Sum(case when EmployeeType <> '''' then Cnt else 0 end) ' +
' from VDepartmentEmployeeType GROUP BY Id, Department ' )

執(zhí)行結(jié)果如下:
部門(mén)編號(hào) 部門(mén)名稱(chēng) 辭退 臨時(shí) 正式 合計(jì)
----------- ---------- ----------- ----------- ----------- -----------
1 A 0 1 2 3
2 B 1 0 2 3
這個(gè)結(jié)果和前面硬編碼的結(jié)果是一樣的,但我們通過(guò)程序來(lái)獲取了所有的員工類(lèi)型,這樣做的好處是如果我們新增了一個(gè)員工類(lèi)型,比如“合同工”,我們不需要修改程序,就可以得到我們想要的輸出。

如果你的數(shù)據(jù)庫(kù)是SQLSERVER 2005 或以上,也可以采用SQLSERVER2005 通過(guò)的新功能 PIVOT
復(fù)制代碼 代碼如下:

SELECT Id as ' 部門(mén)編號(hào) ' , Department as ' 部門(mén)名稱(chēng) ' , [ 正式 ] , [ 臨時(shí) ] , [ 辭退 ]
FROM
( SELECT Id,Department,EmployeeType,Cnt
FROM VDepartmentEmployeeType) p
PIVOT
( SUM (Cnt)
FOR EmployeeType IN ( [ 正式 ] , [ 臨時(shí) ] , [ 辭退 ] )
) AS unpvt

結(jié)果如下
部門(mén)編號(hào) 部門(mén)名稱(chēng) 正式 臨時(shí) 辭退
----------- ---------- ----------- ----------- -----------
1 A 2 1 NULL
2 B 2 NULL 1
NULL 可以通過(guò) ISNULL 函數(shù)來(lái)強(qiáng)制轉(zhuǎn)換為0,這里我就不寫(xiě)出具體的SQL語(yǔ)句了。這個(gè)功能感覺(jué)還是不錯(cuò),不過(guò)合計(jì)好像用這種方法不太好搞。不知道各位同行有沒(méi)有什么好辦法。

相關(guān)文章

  • 如何控制SQLServer中的跟蹤標(biāo)記

    如何控制SQLServer中的跟蹤標(biāo)記

    對(duì)于DBA來(lái)說(shuō),掌握Trace Flag是一個(gè)成為SQL Server高手的必要條件之一,在大多數(shù)情況下,Trace Flag只是一個(gè)劍走偏鋒的奇招,不必要,但在很多情況下,會(huì)使用這些標(biāo)記可以讓你更好的控制SQL Server的行為
    2013-08-08
  • MyBatis實(shí)踐之動(dòng)態(tài)SQL及關(guān)聯(lián)查詢(xún)

    MyBatis實(shí)踐之動(dòng)態(tài)SQL及關(guān)聯(lián)查詢(xún)

    MyBatis,大家都知道,半自動(dòng)的ORM框架,原來(lái)叫ibatis,后來(lái)好像是10年apache軟件基金組織把它托管給了goole code,就重新命名了MyBatis,功能相對(duì)以前更強(qiáng)大了。本文給大家介紹MyBatis實(shí)踐之動(dòng)態(tài)SQL及關(guān)聯(lián)查詢(xún),對(duì)mybatis動(dòng)態(tài)sql相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧
    2016-03-03
  • SQL查詢(xún)字段被包含語(yǔ)句

    SQL查詢(xún)字段被包含語(yǔ)句

    說(shuō)到SQL的模糊查詢(xún),最先想到的,應(yīng)該就是like關(guān)鍵字。當(dāng)我們需要查詢(xún)包含某個(gè)特定字段的數(shù)據(jù)時(shí),往往會(huì)使用 ‘%關(guān)鍵字%’ 查詢(xún)的方式。具體代碼示例大家參考下本文
    2017-07-07
  • SQLSERVER對(duì)索引的利用及非SARG運(yùn)算符認(rèn)識(shí)

    SQLSERVER對(duì)索引的利用及非SARG運(yùn)算符認(rèn)識(shí)

    SQL對(duì)篩選條件簡(jiǎn)稱(chēng):SARG(search argument/SARG)當(dāng)然這里不是說(shuō)SQLSERVER的where子句,是說(shuō)SQLSERVER對(duì)索引的利用,感興趣的朋友可以了解下,或許本文的知識(shí)點(diǎn)對(duì)你有所幫助哈
    2013-02-02
  • 將Session值儲(chǔ)存于SQL Server中

    將Session值儲(chǔ)存于SQL Server中

    將Session值儲(chǔ)存于SQL Server中...
    2007-03-03
  • SQL?Server還原完整備份和差異備份的操作過(guò)程

    SQL?Server還原完整備份和差異備份的操作過(guò)程

    這篇文章主要介紹了SQL?Server?還原?完整備份和差異備份的詳細(xì)操作,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-09-09
  • SQL Server 在分頁(yè)獲取數(shù)據(jù)的同時(shí)獲取到總記錄數(shù)

    SQL Server 在分頁(yè)獲取數(shù)據(jù)的同時(shí)獲取到總記錄數(shù)

    本文通過(guò)兩種方法給大家介紹SQL Server 在分頁(yè)獲取數(shù)據(jù)的同時(shí)獲取到總記錄數(shù),感興趣的朋友跟隨腳本之家小編一起學(xué)習(xí)吧
    2018-05-05
  • SQLite之Autoincrement關(guān)鍵字(自動(dòng)遞增)

    SQLite之Autoincrement關(guān)鍵字(自動(dòng)遞增)

    SQLite 的 AUTOINCREMENT 是一個(gè)關(guān)鍵字,用于表中的字段值自動(dòng)遞增,關(guān)鍵字 AUTOINCREMENT 只能用于整型(INTEGER)字段。
    2015-10-10
  • sql高級(jí)技巧幾個(gè)有用的Sql語(yǔ)句

    sql高級(jí)技巧幾個(gè)有用的Sql語(yǔ)句

    sql語(yǔ)句對(duì)于數(shù)據(jù)的一些操作,根據(jù)另外一個(gè)表的內(nèi)容修改第一個(gè)表的內(nèi)容
    2008-08-08
  • sql?server自動(dòng)生成拼音首字母的函數(shù)

    sql?server自動(dòng)生成拼音首字母的函數(shù)

    建立一個(gè)查詢(xún),執(zhí)行語(yǔ)句生成函數(shù)fn_GetPy,下面是具體的實(shí)現(xiàn),需要的朋友可以參考下
    2014-01-01

最新評(píng)論