国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > SQL Server > 正文

SQLServer行轉(zhuǎn)列實現(xiàn)思路記錄

2024-08-31 01:02:10
字體:
供稿:網(wǎng)友
最近面試遇到了一道面試題,頓時有點迷糊,只說出了思路,后來百度了一下,整理了一下思路,于是記錄下來,方便以后學習。(面試題請參見附件)

相關(guān)的數(shù)據(jù)表:

1.Score表

SQLServer行轉(zhuǎn)列實現(xiàn)思路記錄

 
2.[User]表

SQLServer行轉(zhuǎn)列實現(xiàn)思路記錄

 
SQL語句如下:

--方法一:靜態(tài)SQL

復制代碼 代碼如下:


SELECT * FROM
(SELECT UID,Name, Score,ScoreName FROM Score,[User] WHERE Score.UID=[User].ID) AS SourceTable
PIVOT(AVG(Score)FOR ScoreName IN ([英語], [數(shù)學])) AS a


--方法二:動態(tài)SQL

復制代碼 代碼如下:


DECLARE @s NVARCHAR(4000)
SELECT @s = ISNULL(@s + ',', '') + QUOTENAME(ScoreName)
FROM (select distinct ScoreName from Score) as A ---列名不要重復

Declare @sql NVARCHAR(4000)
SET @sql='
select r.* from
(select UID,Name,ScoreName,Score from Score,[User] where Score.UID=[User].ID) as t
pivot
(
max(t.Score)
for t.ScoreName in ('+@s+')
) as r'
EXEC( @sql)


--方法三:Case When

復制代碼 代碼如下:


select
row_number() OVER(ORDER BY [User].ID) as 編號,
UID as 用戶編號,
Name as 姓名,
max(case ScoreName when '英語' then Score else 0 end) 英語,
max(case ScoreName when '數(shù)學' then Score else 0 end) 數(shù)學
from Score,[User] WHERE Score.UID=[User].ID
group by UID,[User].ID,Name

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 定南县| 闻喜县| 汉沽区| 大名县| 横山县| 施甸县| 隆化县| 新疆| 扎囊县| 临湘市| 新巴尔虎右旗| 集安市| 齐河县| 凤翔县| 永年县| 东平县| 灵璧县| 蚌埠市| 章丘市| 武宣县| 青神县| 南雄市| 蓝山县| 施甸县| 盖州市| 建始县| 龙江县| 崇州市| 防城港市| 鸡泽县| 睢宁县| 封丘县| 清丰县| 新兴县| 石门县| 翼城县| 丹寨县| 新邵县| 深水埗区| 北海市| 泰来县|