SQL Server 交叉表查詢 case
更新時間:2011年12月26日 23:58:06 作者:
今天下午忙于將access數(shù)據(jù)庫中的交叉表轉(zhuǎn)到SQL server數(shù)據(jù)庫中,在SQL server中,不支持transfrom方法,查找相關(guān)資料,找到使用case方法進(jìn)行轉(zhuǎn)換
代碼如下所示:
表landundertake結(jié)構(gòu)如下所示:

表appraiser結(jié)構(gòu)如下所示:

access代碼:
復(fù)制代碼 代碼如下:
TRANSFORM First(Landundertake.valuerId) AS valuerId之First
SELECT Appraiser.quarterId, Landundertake.landCode
FROM Landundertake INNER JOIN Appraiser ON (Landundertake .valuerId = Appraiser.valuerID) AND (Landundertake .quarterId = Appraiser.quarterId)
GROUP BY Appraiser.quarterId, Landundertake .landCode
PIVOT Landundertake .valuerGrade;
SQL server代碼:
復(fù)制代碼 代碼如下:
select dbo.appraiser.quarterID,dbo.landUndertake.landcode,case dbo.landUndertake.appraiserGrade when 'appraiserID1' then dbo.landundertake.appraiserID else null END as appraiserID,case dbo.landUndertake.appraiserGrade when 'appraiserID2' then dbo.landundertake.appraiserID else null END as appraiserID1
from dbo.LandUndertake inner join
dbo.Appraiser ON dbo.LandUndertake.quarterID=dbo.appraiser.quarterID and dbo.landundertake.appraiserID=DBO.Appraiser.appraiserID
Group by dbo.appraiser.quarterID,dbo.landUndertake.landcode,dbo.landundertake.appraiserGrade,dbo.landundertake.appraiserID
交叉表查詢結(jié)果如下所示:

相關(guān)文章
數(shù)據(jù)庫更新Sqlserver腳本總結(jié)
數(shù)據(jù)庫更新Sqlserver腳本總結(jié),需要的朋友可以參考下。2011-06-06
由于系統(tǒng)錯誤 126 (SQL Server),指定驅(qū)動程序無法加載
今天下午在給客戶安裝用友T3標(biāo)準(zhǔn)版時碰到一個非常棘手的問題,MSDE2000數(shù)據(jù)庫和用友T3軟件都安裝好了,但是打開系統(tǒng)管理的時候提示:AUTOMATION錯誤,然后將數(shù)據(jù)庫徹底卸載干凈,用友通T3軟件也徹底卸載干凈,重新安裝了一下,仍然是這個情況2021-03-03
sqlserver數(shù)據(jù)庫優(yōu)化解析(圖文剖析)
這篇文章主要介紹了sql數(shù)據(jù)庫查詢數(shù)據(jù)慢,針對如何優(yōu)化sqlserver數(shù)據(jù)庫做介紹,需要的朋友可以參考下2015-07-07
SQLSERVER Pager store procedure分頁存儲過程
SQL SERVER(2005)以上版本可用,相對應(yīng)的頁面邏輯中寫的對應(yīng)調(diào)用該存儲過程的方法2010-06-06
存儲過程解密(破解函數(shù),過程,觸發(fā)器,視圖.僅限于SQLSERVER2000)
解密指定存儲過程 exec sp_decrypt '存儲過程名'2009-05-05

