SQLServer列转行操作及union all用法

1.创建测试表及数据sql如下

create table ScoresTable(

Name varchar(50),

ChineseScore int,

MathScore int

)

insert into ScoresTable values('小张',90,95)

insert into ScoresTable values('小王',98,99)

2.表中查询结果如下

3.现需列转行显示,每行显示 姓名,科目,成绩

实现sql如下:

select * from

(

select Name, Subject ='语文',Scores=ChineseScore from ScoresTable

union all

select Name, Subject ='数学',Scores=MathScore from ScoresTable

) t

order by Name ,Subject

运行结果如下,实现了列转行

相关推荐
uzong1 小时前
程序员从大厂回重庆工作一年
java·后端·面试
码事漫谈5 小时前
【精华】C++成员初始化列表完全指南:为什么、何时以及如何正确使用
后端
shizhan_cloud5 小时前
Shell 函数的知识与实践
linux·运维
码事漫谈5 小时前
C++ 强制类型转换:类型安全的多维工具
后端
一颗宁檬不酸5 小时前
文件管理知识点
数据库
5 小时前
达梦数据库-事务
数据库·达梦数据库·dm
网硕互联的小客服6 小时前
MYSQL数据库和MSSQL数据库有什么区别?分别适用于什么脚本程序?
数据库·mysql·sqlserver
RainbowSea6 小时前
github 仓库主页美化定制
后端
RainbowSea6 小时前
从 Spring Boot 2.x 到 3.5.x + JDK21:一次完整的生产环境迁移实战
java·spring boot·后端
笨手笨脚の6 小时前
Spring Core常见错误及解决方案
java·后端·spring