麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 數據庫 > SQL Server > 正文

SQLServer行轉列實現思路記錄

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

相關的數據表:

1.Score表

SQLServer行轉列實現思路記錄

 
2.[User]表

SQLServer行轉列實現思路記錄

 
SQL語句如下:

--方法一:靜態SQL

復制代碼 代碼如下:


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


--方法二:動態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 '數學' then Score else 0 end) 數學
from Score,[User] WHERE Score.UID=[User].ID
group by UID,[User].ID,Name

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 国产精品91在线 | 三级xxxx | 高清国产午夜精品久久久久久 | 精品一区二区6 | 大学生一级毛片在线视频 | 亚洲福利在线观看视频 | 激情大乳女做爰办公室韩国 | 第一区免费在线观看 | 日韩av电影免费在线观看 | 奶子吧naiziba.cc免费午夜片在线观看 | 九一传媒在线观看 | 九九热视频在线免费观看 | 欧美视频在线一区二区三区 | 日本不卡一区二区三区在线观看 | freexxx69性欧美hd | 婷婷中文字幕一区二区三区 | 在线成人免费观看 | 国产成人av免费看 | 欧美一区二区片 | 精品国产一区二区三区免费 | 国内精品伊人久久久久网站 | 极品美女一级毛片 | 久久久久亚洲视频 | 视频在线中文字幕 | 91九色视频在线播放 | 欧美一级性 | 91精品国产日韩91久久久久久360 | 天堂精品在线 | 女教师~淫辱の动漫在线 | 欧美成人激情在线 | 欧美中文字幕一区二区三区亚洲 | xxxx hd video 69 | 杏美月av | 国产精品性夜天天视频 | 黄色片网站在线免费观看 | 99精美视频 | 国产91亚洲精品一区二区三区 | 欧美亚洲黄色 | 亚洲男人一区 | 在线播放免费视频 | 国产一区二区在线免费观看 |