SQLServer行转列实现思路记录
我们有两个主要的数据表:Score表和User表。我们需要通过SQL语句将Score表中的多行数据转换成列的形式展示。
方法一:静态SQL
```sql
SELECT
UID,
Name,
[英语] = AVG(CASE WHEN ScoreName = '英语' THEN Score ELSE NULL END),
[数学] = AVG(CASE WHEN ScoreName = '数学' THEN Score ELSE NULL END)
FROM Score
JOIN User ON Score.UID = User.ID
GROUP BY UID, Name;
```
方法二:动态SQL
```sql
DECLARE @columns NVARCHAR(MAX) = ''; -- 用于存储列名的变量
SELECT @columns = (SELECT STRING_AGG(QUOTENAME(ScoreName), ', ') FROM Score GROUP BY ScoreName ORDER BY ScoreName); -- 构建列名列表
DECLARE @sql NVARCHAR(MAX) = 'SELECT UID, Name, ' + @columns + ' FROM Score JOIN User ON Score.UID = User.ID GROUP BY UID, Name'; -- 构建完整的SQL语句
EXEC sp_executesql @sql; -- 执行动态SQL语句
```
方法三:Case When
你给出的方法三已经相当清晰,以下是稍作改动的版本:
```sql
SELECT
编号 = ROW_NUMBER() OVER(ORDER BY User.ID),
用户编号 = UID,
姓名 = Name,
英语 = MAX(CASE WHEN ScoreName = '英语' THEN Score ELSE NULL END),
数学 = MAX(CASE WHEN ScoreName = '数学' THEN Score ELSE NULL END)
FROM Score JOIN User ON Score.UID = User.ID GROUP BY UID, Name;
```
编程语言
- Win10 PC创意者更新慢速版15048改进内容与已知问题
- 用纯CSS3实现网页中常见的小箭头
- 神舟笔记本问题集锦
- Bellnames常用操作说明
- 揭秘手机淘宝搜索排序的影响因素
- XHTML入门学习教程-网页Head和DTD
- 笔记本光驱保养常用知识
- hzhost虚拟主机系统致命漏洞
- 电脑无线网络出现红色叉叉无线网卡打不开的六
- 16项评比不得不看 机箱哪些功能最实用
- AI怎么绘制一个呲牙的qq表情-
- 红帽指点杆机械键盘 TEX Yoda上手体验测评
- 笔记本电脑保养常识有哪些-笔记本保养常识总结
- cdr怎么设计圆角矩形效果的图标-
- 在XSLT样式表中声明命名空间小结
- Fireworks教程-常用操作技巧总结