SQL Server數據庫基礎之行數據轉換為列數據
文章主要給大家介紹了關于SQL Server基礎之行數據轉換為列數據的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用SQL Server具有一定的參考學習價值,需要的朋友們...
文章主要給大家介紹了關于SQL Server基礎之行數據轉換為列數據的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用SQL Server具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
準備工作
創建表
use [test1]
go
create table [dbo].[student](
[id] [int] identity(1,1) not null,
[name] [nvarchar](50) null,
[project] [nvarchar](50) null,
[score] [int] null,
constraint [pk_student] primary key clustered
(
[id] asc
)with (pad_index = off, statistics_norecompute = off, ignore_dup_key = off, allow_row_locks = on, allow_page_locks = on) on [primary]
) on [primary]
go
插入數據
insert into test1.dbo.student(name,project,score)
values('張三','android','60'),
('張三','iOS','70'),
('張三','html5','55'),
('張三','.net','100'),
('李四','android','60'),
('李四','ios','75'),
('李四','html5','90'),
('李四','.net','100');
使用Case When和聚合函數進行行專列
語法
select column_name,
<aggregation function>(<case when expression>)
from database.schema.table
group by column_name
語法解析
column_name
數據列列名
aggregation function
聚合函數,常見的有:sum,max,min,avg,count等。
case when expression
case when表達式
示例
select name,
max(case project when 'android' then score end) as '安卓',
max(case project when 'ios' then score end) as '蘋果',
max(case project when 'html5' then score end) as 'html5',
max(case project when '.net' then score end) as '.net'
from [test1].[dbo].[student]
group by name
示例結果
轉換前
轉換后
使用PIVOT進行行專列
PIVOT通過將表達式中一列中的唯一值轉換為輸出中的多個列來旋轉表值表達式。并PIVOT在最終輸出中需要的任何剩余列值上運行聚合,PIVOT提供比一系列復雜的SELECT...CASE語句指定的語法更為簡單和可讀的語法,PIVOT執行聚合并將可能的多行合并到輸出中的單個行中。
語法
select <non-pivoted column>,
[first pivoted column] as <column name>,
[second pivoted column] as <column name>,
...
[last pivoted column] as <column name>
from
(<select query that produces the data>)
as <alias for the source query>
pivot
(
<aggregation function>(<column being aggregated>)
for
[<column that contains the values that will become column headers>]
in ( [first pivoted column], [second pivoted column],
... [last pivoted column])
) as <alias for the pivot table>
<optional order by clause>;
語法解析
<non-pivoted column>
非聚合列。
[first pivoted column]
第一列列名。
[second pivoted column]
第二列列名。
[last pivoted column]
最后一列列名。
<select query that produces the data>
數據子表。
<alias for the source query>
表別名。
<aggregation function>
聚合函數。
<column being aggregated>
聚合函數列,用于輸出值列,最終輸出中返回的列(稱為分組列)將對其進行分組。
[<column that contains the values that will become column headers>]
轉換列,此列返回的唯一值將成為最終結果集中的字段。
[first pivoted column], [second pivoted column], ... [last pivoted column]
數據行中每一行行要轉換的列名。
<optional order by clause>
排序規則。
示例
select b.Name,b.[android],b.[ios],b.[html5],b.[.net]
from
(select Name,Project,Score from [test1].[dbo].[student])
as a
pivot
(
max(Score)
for Project in ([android],[ios],[html5],[.net])
)
as b
order by b.name desc
示例結果
轉換前
轉換后
注意事項
1、如果輸出列名不能在表轉換列中,則不會執行任何計算。
2、輸出的所有列的列名的數據類型必須一致。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值。
SQL server數據庫創建代碼 filegroup文件組修改的示例代碼
文章主要介紹了SQL server數據庫創建代碼 filegroup文件組修改的實現方法,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下數據庫的操作:1. 對數據文件...
SQLServer數據庫處于恢復掛起狀態的解決辦法
文章主要介紹了SQLServer數據庫處于恢復掛起狀態的解決辦法 ,本文圖文并茂給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下.一、總結 如果數據庫處...
SQL Server數據庫之datepart和datediff應用查找當天上午和下午的數據
文章主要介紹了sqlserver之datepart和datediff應用查找當天上午和下午的數據,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下DATEPART() 函數用于返回日期/時間的單獨...
SQL Server數據庫中的數據類型隱式轉換問題
文章主要介紹了SQL Server 中的數據類型隱式轉換問題,本文給大家介紹的非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下寫這篇文章的時候,還真不知道如何取名,也不知道這...
Thinkphp5框架實現獲取數據庫數據到視圖的方法
文章主要介紹了Thinkphp5框架實現獲取數據庫數據到視圖的方法,涉及thinkPHP5數據庫配置、讀取、模型操作及視圖調用相關操作技巧,需要的朋友可以參考下。這是學習thinkhp5的...
Linux下使用ps命令來查看oracle數據庫相關進程的操作步驟
ps命令的操作是很多的小伙伴在管理進程的操作的時候遇到的問題,對于Linux系統中今天小編就來跟大家分享一下詳解Oracle相關進程在電腦中使用ps命令查看的操作步驟。...
如何使用Access數據庫創建一個簡單MIS管理系統
MIS管理系統也是一種很實用的管理系統,可以將很多東西都放的井井有條,便于大家查找,下文中就以大家家中都有的CD、VCD為例,為大家介紹如何建立一個MIS管理系統,使這些東西有條理。...
Access數據庫日常維護和Access數據庫優化方法
文章主要介紹了Access數據庫日常維護方法(優化),適用范圍:使用Access作為數據庫建設的網站。需要的朋友可以參考下...
MariaDB數據庫的外鍵約束實例代碼介紹詳解
文章主要給大家介紹了關于MariaDB數據庫的外鍵約束的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考借鑒,下面隨著小編來一起學習學習吧...
Windows10系統下MariaDB數據庫安裝教程圖解
文章給大家介紹Windows10系統下安裝MariaDB 的教程圖解,感興趣的朋友一起看看吧,MariaDB由MySQL的創始人麥克爾·維德紐斯主導開發,...