當前位置:首頁 » 數據倉庫 » 資料庫行變列
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

資料庫行變列

發布時間: 2022-09-13 09:56:07

sql怎樣將行的值變為列,,,,

方法/步驟

  • 首先我們建立一張表,名為RToC,各個欄位的設計如下圖,分別是name,course,score,表示姓名,成績與分數,如圖所示。

  • 通過以上幾個步驟,我們就可以輕松的實現行列轉換了。同樣,我們如果要把列轉換成行, 應該怎麼做呢?同樣我們可以採用unpivot函數輕松實現。

❷ SqlServer資料庫怎麼實現行轉列的sql語句

PIVOT 用於將列值旋轉為列名(即行轉列),在 SQL Server 2000可以用聚合函數配合CASE語句實現
PIVOT 的一般語法是:PIVOT(聚合函數(列) FOR 列 in (…) )AS P
注意:PIVOT、UNPIVOT是SQL Server 2005 的語法,使用需修改資料庫兼容級別(在資料庫屬性->選項->兼容級別改為 90 )
SQL2008 中可以直接使用
完整語法:

table_source

PIVOT(

聚合函數(value_column)

FOR pivot_column

IN(<column_list>)

)

View Code
UNPIVOT 用於將列明轉為列值(即列轉行),在SQL Server 2000可以用UNION來實現

完整語法:

table_source

UNPIVOT(

value_column

FOR pivot_column

IN(<column_list>)

)

❸ Oracle 資料庫行轉列

createtableA(名稱varchar2(10),"1月"varchar2(10),"2月"varchar2(10),"3月"varchar2(10),"4月"varchar2(10))

insertintoAvalues('土豆',50,60,70,80);

insertintoAvalues('白菜',150,160,170,180);

commit;

select*fromA;

select*from(

select名稱,'1月'月份,"1月"值fromA

unionall

select名稱,'2月'月份,"2月"值fromA

unionall

select名稱,'3月'月份,"3月"值fromA

unionall

select名稱,'4月'月份,"4月"值fromA)

where名稱='土豆'

結果:

❹ sql 行變成列

declare@snvarchar(4000)
select@s=isnull(@s+',','')+quotename(Name)
fromsyscolumnswhereID=object_id('aa')
orderbyColid
exec('selectid,namefromaaunpivot(nameforidin('+@s+'))b')

如圖:

❺ postgre資料庫如何實現行轉列

表結構及數據

❻ SQL語句,行變列,請高手指點

樓主,你好!SQL行列轉換我有參照過別人的,現在貼出來給你看看。

/*
標題:普通行列轉換(version2.0)
作者:愛新覺羅.毓華(十八年風雨,守得冰山雪蓮花開)
時間:-03-09
地點:廣東深圳
說明:普通行列轉換(version1.0)僅針對sqlserver2000提供靜態和動態寫法,version2.0增加sqlserver2005的有關寫法。

問題:假設有張學生成績表(tb)如下:
姓名課程分數
張三語文74
張三數學83
張三物理93
李四語文74
李四數學84
李四物理94
想變成(得到如下結果):
姓名語文數學物理
----------------
李四748494
張三748393
-------------------
*/

createtabletb(姓名varchar(10),課程varchar(10),分數int)
insertintotbvalues('張三','語文',74)
insertintotbvalues('張三','數學',83)
insertintotbvalues('張三','物理',93)
insertintotbvalues('李四','語文',74)
insertintotbvalues('李四','數學',84)
insertintotbvalues('李四','物理',94)
go

--SQLSERVER2000靜態SQL,指課程只有語文、數學、物理這三門課程。(以下同)
select姓名as姓名,
max(case課程when'語文'then分數else0end)語文,
max(case課程when'數學'then分數else0end)數學,
max(case課程when'物理'then分數else0end)物理
fromtb
groupby姓名

--SQLSERVER2000動態SQL,指課程不止語文、數學、物理這三門課程。(以下同)
declare@sqlvarchar(8000)
set@sql='select姓名'
select@sql=@sql+',max(case課程when'''+課程+'''then分數else0end)['+課程+']'
from(selectdistinct課程fromtb)asa
set@sql=@sql+'fromtbgroupby姓名'
exec(@sql)

--SQLSERVER2005靜態SQL。
select*from(select*fromtb)apivot(max(分數)for課程in(語文,數學,物理))b

--SQLSERVER2005動態SQL。
declare@sqlvarchar(8000)
select@sql=isnull(@sql+'],[','')+課程fromtbgroupby課程
set@sql='['+@sql+']'
exec('select*from(select*fromtb)apivot(max(分數)for課程in('+@sql+'))b')

---------------------------------

/*
問題:在上述結果的基礎上加平均分,總分,得到如下結果:
姓名語文數學物理平均分總分
--------------------------
李四74849484.00252
張三74839383.33250
*/

--SQLSERVER2000靜態SQL。
select姓名姓名,
max(case課程when'語文'then分數else0end)語文,
max(case課程when'數學'then分數else0end)數學,
max(case課程when'物理'then分數else0end)物理,
cast(avg(分數*1.0)asdecimal(18,2))平均分,
sum(分數)總分
fromtb
groupby姓名

--SQLSERVER2000動態SQL。
declare@sqlvarchar(8000)
set@sql='select姓名'
select@sql=@sql+',max(case課程when'''+課程+'''then分數else0end)['+課程+']'
from(selectdistinct課程fromtb)asa
set@sql=@sql+',cast(avg(分數*1.0)asdecimal(18,2))平均分,sum(分數)總分fromtbgroupby姓名'
exec(@sql)

--SQLSERVER2005靜態SQL。
selectm.*,n.平均分,n.總分from
(select*from(select*fromtb)apivot(max(分數)for課程in(語文,數學,物理))b)m,
(select姓名,cast(avg(分數*1.0)asdecimal(18,2))平均分,sum(分數)總分fromtbgroupby姓名)n
wherem.姓名=n.姓名

--SQLSERVER2005動態SQL。
declare@sqlvarchar(8000)
select@sql=isnull(@sql+',','')+課程fromtbgroupby課程
exec('selectm.*,n.平均分,n.總分from
(select*from(select*fromtb)apivot(max(分數)for課程in('+@sql+'))b)m,
(select姓名,cast(avg(分數*1.0)asdecimal(18,2))平均分,sum(分數)總分fromtbgroupby姓名)n
wherem.姓名=n.姓名')

droptabletb

------------------
------------------

/*
問題:如果上述兩表互相換一下:即表結構和數據為:
姓名語文數學物理
張三74
李四74
想變成(得到如下結果):
姓名課程分數
------------
李四語文74
李四數學84
李四物理94
張三語文74
張三數學83
張三物理93
--------------
*/

createtabletb(姓名varchar(10),語文int,數學int,物理int)
insertintotbvalues('張三',74,83,93)
insertintotbvalues('李四',74,84,94)
go

--SQLSERVER2000靜態SQL。
select*from
(
select姓名,課程='語文',分數=語文fromtb
unionall
select姓名,課程='數學',分數=數學fromtb
unionall
select姓名,課程='物理',分數=物理fromtb
)t
orderby姓名,case課程when'語文'then1when'數學'then2when'物理'then3end

--SQLSERVER2000動態SQL。
--調用系統表動態生態。
declare@sqlvarchar(8000)
select@sql=isnull(@sql+'unionall','')+'select姓名,[課程]='+quotename(Name,'''')+',[分數]='+quotename(Name)+'fromtb'
fromsyscolumns
wherename!=N'姓名'andID=object_id('tb')--表名tb,不包含列名為姓名的其它列
orderbycolidasc
exec(@sql+'orderby姓名')

--SQLSERVER2005動態SQL。
select姓名,課程,分數fromtbunpivot(分數for課程in([語文],[數學],[物理]))t

--SQLSERVER2005動態SQL,同SQLSERVER2000動態SQL。

--------------------
/*
問題:在上述的結果上加個平均分,總分,得到如下結果:
姓名課程分數
----------------
李四語文74.00
李四數學84.00
李四物理94.00
李四平均分84.00
李四總分252.00
張三語文74.00
張三數學83.00
張三物理93.00
張三平均分83.33
張三總分250.00
------------------
*/

select*from
(
select姓名as姓名,課程='語文',分數=語文fromtb
unionall
select姓名as姓名,課程='數學',分數=數學fromtb
unionall
select姓名as姓名,課程='物理',分數=物理fromtb
unionall
select姓名as姓名,課程='平均分',分數=cast((語文+數學+物理)*1.0/3asdecimal(18,2))fromtb
unionall
select姓名as姓名,課程='總分',分數=語文+數學+物理fromtb
)t
orderby姓名,case課程when'語文'then1when'數學'then2when'物理'then3when'平均分'then4when'總分'then5end

droptabletb

希望能幫助到你

❼ 資料庫 sql 行列轉換是這樣的嗎

sql行列轉換代碼:
create (keyId int identity,---自動流水號
nian int not null, ---年份
info1 varchar(30),
info2 varchar(30),
qty int ---數量
)

insert into A (nian,info1,info2,qty)values(2012,'A','B',2)
insert into A (nian,info1,info2,qty)values(2013,'B','C',3)
insert into A (nian,info1,info2,qty)values(2008,'C','D',4)
insert into A (nian,info1,info2,qty)values(2018,'D','E',5)
insert into A (nian,info1,info2,qty)values(2012,'A','F',6)
insert into A (nian,info1,info2,qty)values(2008,'B','G',7)
insert into A (nian,info1,info2,qty)values(2012,'C','H',12)
insert into A (nian,info1,info2,qty)values(2013,'D','I',16)
insert into A (nian,info1,info2,qty)values(2013,'A','J',20)
go
--行轉列方法1:CASE WHEN,兼容sql2000
select info1,
sum(case when nian=2012 then qty end) as [2012],
sum(case when nian=2008 then qty end) as [2008],
sum(case when nian=2018 then qty end) as [2018],
sum(case when nian=2013 then qty end) as [2013]
from A
group by info1;
GO
--行轉列方法2:PIVOT,sql2005及以後版本
select *
from (select info1,nian,qty from A) as infotest
pivot(sum(qty) for nian in([2012],[2008],[2018],[2013]))as lie
GO
truncate table A
drop table A

如有疑問,及時溝通!

❽ SQL中 怎麼將行轉為列

*
標題:普通行列轉換(version 2.0)
作者:愛新覺羅.毓華(十八年風雨,守得冰山雪蓮花開)
時間:2008-03-09
地點:廣東深圳
說明:普通行列轉換(version 1.0)僅針對sql server 2000提供靜態和動態寫法,version 2.0增加sql server 2005的有關寫法。

問題:假設有張學生成績表(tb)如下:
姓名 課程 分數
張三 語文 74
張三 數學 83
張三 物理 93
李四 語文 74
李四 數學 84
李四 物理 94
想變成(得到如下結果):
姓名 語文 數學 物理
---- ---- ---- ----
李四 74 84 94
張三 74 83 93
-------------------
*/

create table tb(姓名 varchar(10) , 課程 varchar(10) , 分數 int)
insert into tb values('張三' , '語文' , 74)
insert into tb values('張三' , '數學' , 83)
insert into tb values('張三' , '物理' , 93)
insert into tb values('李四' , '語文' , 74)
insert into tb values('李四' , '數學' , 84)
insert into tb values('李四' , '物理' , 94)
go

--SQL SERVER 2000 靜態SQL,指課程只有語文、數學、物理這三門課程。(以下同)
select 姓名 as 姓名 ,
max(case 課程 when '語文' then 分數 else 0 end) 語文,
max(case 課程 when '數學' then 分數 else 0 end) 數學,
max(case 課程 when '物理' then 分數 else 0 end) 物理
from tb
group by 姓名

--SQL SERVER 2000 動態SQL,指課程不止語文、數學、物理這三門課程。(以下同)
declare @sql varchar(8000)
set @sql = 'select 姓名 '
select @sql = @sql + ' , max(case 課程 when ''' + 課程 + ''' then 分數 else 0 end) [' + 課程 + ']'
from (select distinct 課程 from tb) as a
set @sql = @sql + ' from tb group by 姓名'
exec(@sql)

--SQL SERVER 2005 靜態SQL。
select * from (select * from tb) a pivot (max(分數) for 課程 in (語文,數學,物理)) b

--SQL SERVER 2005 動態SQL。
declare @sql varchar(8000)
select @sql = isnull(@sql + '],[' , '') + 課程 from tb group by 課程
set @sql = '[' + @sql + ']'
exec ('select * from (select * from tb) a pivot (max(分數) for 課程 in (' + @sql + ')) b')

---------------------------------

/*
問題:在上述結果的基礎上加平均分,總分,得到如下結果:
姓名 語文 數學 物理 平均分 總分
---- ---- ---- ---- ------ ----
李四 74 84 94 84.00 252
張三 74 83 93 83.33 250
*/

--SQL SERVER 2000 靜態SQL。
select 姓名 姓名,
max(case 課程 when '語文' then 分數 else 0 end) 語文,
max(case 課程 when '數學' then 分數 else 0 end) 數學,
max(case 課程 when '物理' then 分數 else 0 end) 物理,
cast(avg(分數*1.0) as decimal(18,2)) 平均分,
sum(分數) 總分
from tb
group by 姓名

--SQL SERVER 2000 動態SQL。
declare @sql varchar(8000)
set @sql = 'select 姓名 '
select @sql = @sql + ' , max(case 課程 when ''' + 課程 + ''' then 分數 else 0 end) [' + 課程 + ']'
from (select distinct 課程 from tb) as a
set @sql = @sql + ' , cast(avg(分數*1.0) as decimal(18,2)) 平均分 , sum(分數) 總分 from tb group by 姓名'
exec(@sql)

--SQL SERVER 2005 靜態SQL。
select m.* , n.平均分 , n.總分 from
(select * from (select * from tb) a pivot (max(分數) for 課程 in (語文,數學,物理)) b) m,
(select 姓名 , cast(avg(分數*1.0) as decimal(18,2)) 平均分 , sum(分數) 總分 from tb group by 姓名) n
where m.姓名 = n.姓名

--SQL SERVER 2005 動態SQL。
declare @sql varchar(8000)
select @sql = isnull(@sql + ',' , '') + 課程 from tb group by 課程
exec ('select m.* , n.平均分 , n.總分 from
(select * from (select * from tb) a pivot (max(分數) for 課程 in (' + @sql + ')) b) m ,
(select 姓名 , cast(avg(分數*1.0) as decimal(18,2)) 平均分 , sum(分數) 總分 from tb group by 姓名) n
where m.姓名 = n.姓名')

drop table tb

------------------
------------------

/*
問題:如果上述兩表互相換一下:即表結構和數據為:
姓名 語文 數學 物理
張三 748393
李四 748494
想變成(得到如下結果):
姓名 課程 分數
---- ---- ----
李四 語文 74
李四 數學 84
李四 物理 94
張三 語文 74
張三 數學 83
張三 物理 93
--------------
*/

create table tb(姓名 varchar(10) , 語文 int , 數學 int , 物理 int)
insert into tb values('張三',74,83,93)
insert into tb values('李四',74,84,94)
go

--SQL SERVER 2000 靜態SQL。
select * from
(
select 姓名 , 課程 = '語文' , 分數 = 語文 from tb
union all
select 姓名 , 課程 = '數學' , 分數 = 數學 from tb
union all
select 姓名 , 課程 = '物理' , 分數 = 物理 from tb
) t
order by 姓名 , case 課程 when '語文' then 1 when '數學' then 2 when '物理' then 3 end

--SQL SERVER 2000 動態SQL。
--調用系統表動態生態。
declare @sql varchar(8000)
select @sql = isnull(@sql + ' union all ' , '' ) + ' select 姓名 , [課程] = ' + quotename(Name , '''') + ' , [分數] = ' + quotename(Name) + ' from tb'
from syscolumns
where name! = N'姓名' and ID = object_id('tb') --表名tb,不包含列名為姓名的其它列
order by colid asc
exec(@sql + ' order by 姓名 ')

--SQL SERVER 2005 動態SQL。
select 姓名 , 課程 , 分數 from tb unpivot (分數 for 課程 in([語文] , [數學] , [物理])) t

--SQL SERVER 2005 動態SQL,同SQL SERVER 2000 動態SQL。

--------------------
/*
問題:在上述的結果上加個平均分,總分,得到如下結果:
姓名 課程 分數
---- ------ ------
李四 語文 74.00
李四 數學 84.00
李四 物理 94.00
李四 平均分 84.00
李四 總分 252.00
張三 語文 74.00
張三 數學 83.00
張三 物理 93.00
張三 平均分 83.33
張三 總分 250.00
------------------
*/

select * from
(
select 姓名 as 姓名 , 課程 = '語文' , 分數 = 語文 from tb
union all
select 姓名 as 姓名 , 課程 = '數學' , 分數 = 數學 from tb
union all
select 姓名 as 姓名 , 課程 = '物理' , 分數 = 物理 from tb
union all
select 姓名 as 姓名 , 課程 = '平均分' , 分數 = cast((語文 + 數學 + 物理)*1.0/3 as decimal(18,2)) from tb
union all
select 姓名 as 姓名 , 課程 = '總分' , 分數 = 語文 + 數學 + 物理 from tb
) t
order by 姓名 , case 課程 when '語文' then 1 when '數學' then 2 when '物理' then 3 when '平均分' then 4 when '總分' then 5 end

drop table tb

❾ oracle資料庫關於把表的行變成列

姓名 數學 語文 姓名 張飛 趙雲 龐統
張飛 60 61 數學 60 80 99
趙雲 80 85 變成 語文 61 85 80
龐統 99 80
而且第一行為列名,不是表中的數據,這樣的話
也就是第一個表下面三行的數據,變成第二個表下面兩行的數據
這樣還是可以的

❿ SQL 行轉列

我這里兩種都給你介紹,行轉列和列轉行:

列轉行——

錄入經營范圍時候會遇到列傳行的問題解決方案如下:

在temp1 表有一下欄位內容: