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

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

SQLServer行轉列實現思路記錄

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

相關的數據表:

1.Score表
 
2.[User]表
 
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
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 勃利县| 吉安县| 黔南| 洛隆县| 南皮县| 康保县| 体育| 厦门市| 雅安市| 克东县| 资兴市| 故城县| 连城县| 额敏县| 轮台县| 彩票| 陕西省| 黄龙县| 蒙自县| 娱乐| 上栗县| 镇雄县| 江孜县| 鹿邑县| 台南县| 应城市| 夹江县| 额济纳旗| 元氏县| 田林县| 台湾省| 崇礼县| 专栏| 香格里拉县| 余庆县| 漯河市| 丽江市| 额尔古纳市| 绥棱县| 焦作市| 略阳县|