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

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

相关推荐
Mr_Orangechen5 分钟前
Linux 下使用 VS Code 远程 GDB 调试 ARM 程序
linux·运维·arm开发
全栈凯哥5 分钟前
16.Spring Boot 国际化完全指南
java·spring boot·后端
M1A112 分钟前
Java集合框架深度解析:LinkedList vs ArrayList 的对决
java·后端
撰卢21 分钟前
【个人笔记】负载均衡
运维·笔记·负载均衡
~ 小团子25 分钟前
每日一SQL 【各赛事的用户注册率】
数据库·sql
llm20090938 分钟前
Jmeter的JDBC数据库连接
数据库·jmeter
lilian1291 小时前
linux系统mysql性能优化
linux·运维·mysql
小袁拒绝摆烂1 小时前
SQL开窗函数
android·sql·性能优化
betazhou1 小时前
SQL server之版本的初认知
数据库·oracle·goldengate·sql server·ogg·gdr
superonion06201 小时前
【DB2】load报错SQL3501W、SQL3109N、SQL2036N
数据库