日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > 数据库 >内容正文

数据库

SQL语句行列转换两种方法 case ...when 和pivot函数应用

發(fā)布時(shí)間:2025/5/22 数据库 60 豆豆
生活随笔 收集整理的這篇文章主要介紹了 SQL语句行列转换两种方法 case ...when 和pivot函数应用 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

2019獨(dú)角獸企業(yè)重金招聘Python工程師標(biāo)準(zhǔn)>>>


?? SQL語(yǔ)句行列轉(zhuǎn)換兩種方法 case ...when 和pivot函數(shù)應(yīng)用SQL語(yǔ)句行列轉(zhuǎn)換兩種方法 case ...when
和pivot函數(shù)應(yīng)用,運(yùn)用pivot 函數(shù)只支持?jǐn)?shù)據(jù)庫(kù)版本2005以上的。一般運(yùn)用case? when else end 的方法
比較多,比較普遍。

?/*創(chuàng)建數(shù)據(jù)庫(kù)*/
?CREATE DATABASE tmp
?go
?USE tmp
?go


? /*創(chuàng)建數(shù)據(jù)庫(kù)測(cè)試表*/

CREATE TABLE [Scores]
???? (
?????? [ID] INT IDENTITY(1, 1)
??????????????? PRIMARY KEY ,
?????? [Student] VARCHAR(20) ,
?????? [Subject] VARCHAR(30) ,
?????? [Score] FLOAT
???? )

go

TRUNCATE TABLE Scores
?/*插入數(shù)據(jù)庫(kù)測(cè)試數(shù)據(jù)信息*/
??INSERT? INTO Scores
???????? ( Student, Subject, Score )
?VALUES? ( 'test001', '語(yǔ)文', '90' )
?INSERT? INTO Scores
???????? ( Student, Subject, Score )
?VALUES? ( 'test001', '英語(yǔ)', '85' )
?INSERT? INTO Scores
???????? ( Student, Subject, Score )
?VALUES? ( 'text002', '語(yǔ)文', '90' )
?INSERT? INTO Scores
???????? ( Student, Subject, Score )
?VALUES? ( 'text002', '英語(yǔ)', '80' )
?INSERT? INTO Scores
???????? ( Student, Subject, Score )
?VALUES? ( 'test003', '語(yǔ)文', '95' )
?INSERT? INTO Scores
???????? ( Student, Subject, Score )
?VALUES? ( 'test003', '英語(yǔ)', '85' )

/*1.? case when .......then else? ....end 用法,行列轉(zhuǎn)換*/
?SELECT? Student AS '姓名' ,
???????? MAX(CASE Subject
?????????????? WHEN '語(yǔ)文' THEN Score
?????????????? ELSE 0
???????????? END) AS '語(yǔ)文' ,--如果這個(gè)行是“語(yǔ)文”,就選此行作為列
??????? MAX(CASE Subject
?????????????? WHEN '英語(yǔ)' THEN Score
?????????????? ELSE 0
???????????? END) AS '英語(yǔ)'
FROM??? Scores
?GROUP BY Student
?ORDER BY Student

/*2. pivot(聚合函數(shù)(要轉(zhuǎn)成列值的列名)
 ????? for 要轉(zhuǎn)換的列
?  ??? in(目標(biāo)列名)
?  )*/

SELECT? Student AS '姓名' ,
???????? AVG(語(yǔ)文) AS '語(yǔ)文' ,
???????? AVG(英語(yǔ)) AS '英語(yǔ)'
FROM??? Scores PIVOT( AVG(Score) FOR Subject IN ( 語(yǔ)文, 英語(yǔ) ) )as NewScores
?GROUP BY Student
?ORDER BY Student ASC


???

?

轉(zhuǎn)載于:https://my.oschina.net/liangjw0504/blog/151736

總結(jié)

以上是生活随笔為你收集整理的SQL语句行列转换两种方法 case ...when 和pivot函数应用的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。