玩轉-SQL2005數(shù)據(jù)庫行列轉換
注意:列轉行的方法可能是我獨創(chuàng)的了,呵呵,因為在網(wǎng)上找不到哦,全部是我自己寫的,用到了系統(tǒng)的SysColumns
(一)行轉列的方法
先說說行轉列的方法,這個就比較好想了,利用拼sql和case when解決即可
實現(xiàn)目的
1:建立測試用的數(shù)據(jù)庫
CREATE TABLE RowTest(
[Name] [nvarchar](10) NULL,--名稱
[Course] [nvarchar](10) NULL,--課程名稱
[Record] [int] NULL--課程的分數(shù)
)
2:加入測試用的數(shù)據(jù)庫(先加入整齊的數(shù)據(jù))
insert into RowTest values ('張三','語文','91')
insert into RowTest values ('張三','數(shù)學','92')
insert into RowTest values ('張三','英語','93')
insert into RowTest values ('張三','生物','94')
insert into RowTest values ('張三','物理','95')
insert into RowTest values ('張三','化學','96')
insert into RowTest values ('李四','語文','81')
insert into RowTest values ('李四','數(shù)學','82')
insert into RowTest values ('李四','英語','83')
insert into RowTest values ('李四','生物','84')
insert into RowTest values ('李四','物理','85')
insert into RowTest values ('李四','化學','86')
insert into RowTest values ('小生','語文','71')
insert into RowTest values ('小生','數(shù)學','72')
insert into RowTest values ('小生','英語','73')
insert into RowTest values ('小生','生物','74')
insert into RowTest values ('小生','物理','75')
insert into RowTest values ('小生','化學','76')
3:設計想法
行轉列的原理就是把行的類別找出來當做查詢的字段,利用case when 把當前的分數(shù)加到當前的字段上去,最后用group by 把數(shù)據(jù)整合在一起
4:通用方法
declare @sql nvarchar(max)
set @sql='select Name'
select @sql=@sql+','+'isnull(max( case when Course='''+TCourse.Course+''' then Record end ),0)'+TCourse.Course
from (select distinct Course from RowTest)TCourse
set @sql=@sql+' from RowTest group by Name order by Name'
print @sql
exec(@sql)
說明: 把所有的課程名稱取出來作為列(查詢表TCourse)
用case when 的方法把sql 拼出來
5:課外試驗
(1)加入數(shù)據(jù)
insert into dbo.RowTest values ('小生','生物','110')
去除max 方法會報錯,因為一條可能對應多行數(shù)據(jù)
(2)加入數(shù)據(jù)
insert into dbo.RowTest values ('小生','計算機','110')
數(shù)據(jù)會多出一列,但是其他人無此課程就會為0
至此,數(shù)據(jù)行轉列ok
(二)列轉行的新方法開始了
實現(xiàn)目的

1:實現(xiàn)原理
在網(wǎng)上看了別人的做法,基本都是用union all 來一個個轉換的,我覺得不太好用。
首先我想到了要把所有的列名取出來,就在網(wǎng)上查了下獲取表的所有列名
然后我可以把主表和列名形成的表串起來,這樣就可以形成需要的列數(shù),然后根據(jù)判斷取值就完成了了,呵呵
2:建立表格
create table CoulumTest
(
Name nvarchar(10),
語文 int,
數(shù)學 int,
英語 int
)
3:加入數(shù)據(jù)
insert into CoulumTest values(N'張三',90,91,92)
insert into CoulumTest values(N'李四',80,81,82)
4:經(jīng)典的地方來了
select CT.Name,Col.name 課程,
(case when Col.name=N'語文' then CT.語文 when Col.name=N'數(shù)學' then CT.數(shù)學
when Col.name=N'英語' then CT.英語 end ) as 分數(shù) from CoulumTest CT
left join (select name from SysColumns Where id=Object_Id('CoulumTest')) Col on Col.name<>'Name'
你沒看錯,一句話搞定,但是有個問題迷惑了我,我覺得還不夠簡化,如果可以把case when 都不用了就更好了,請大神們指點小弟一下了。怎么根據(jù)
Col的name 直接取得分數(shù)
- sql 普通行列轉換
- 一個簡單的SQL 行列轉換語句
- sqlserver2005 行列轉換實現(xiàn)方法
- Sql實現(xiàn)行列轉換方便了我們存儲數(shù)據(jù)和呈現(xiàn)數(shù)據(jù)
- 深入SQL中PIVOT 行列轉換詳解
- PostgreSQL實現(xiàn)交叉表(行列轉換)的5種方法示例
- sql server通過pivot對數(shù)據(jù)進行行列轉換的方法
- SQL Server 使用 Pivot 和 UnPivot 實現(xiàn)行列轉換的問題小結
- SQL Server使用PIVOT與unPIVOT實現(xiàn)行列轉換
- MySQL實現(xiàn)行列轉換
- SQL行列轉換超詳細四種方法詳解
- SQL Server行列轉換的實現(xiàn)示例
- SQLServer使用 PIVOT 和 UNPIVOT行列轉換
相關文章
SQL Server 2005恢復數(shù)據(jù)庫詳細圖文教程
這篇文章主要介紹了SQL Server 2005恢復數(shù)據(jù)庫詳細圖文教程,需要的朋友可以參考下2014-11-11
使用SQLSERVER 2005/2008 遞歸CTE查詢樹型結構的方法
我們經(jīng)常遇到樹型結構,把它們顯示在一個類似TreeView控件上的情況。這時我們可以使用Recursive Common Table Expressions(CTE)實現(xiàn)2011-10-10
SQL2005CLR函數(shù)擴展-深入環(huán)比計算的詳解
環(huán)比就是本月和上月的差值所占上月值的比例。在復雜的olap計算中我們經(jīng)常會用到同比環(huán)比等概念,要求的上個維度的某個字段的實現(xiàn)語句非常簡練,比如ssas的mdx語句類似[維度].CurrentMember.Prevmember就可以了2013-06-06
SQLServer無法打開用戶默認數(shù)據(jù)庫 登錄失敗錯誤4064的解決方法
這篇文章主要介紹了SQLServer無法打開用戶默認數(shù)據(jù)庫 登錄失敗錯誤4064的解決方法,需要的朋友可以參考下2015-01-01

