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

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

相关推荐
叠叠乐12 分钟前
移动家庭云电脑linux docker 容器登陆移动家庭云电脑
linux·运维·docker
廋到被风吹走14 分钟前
【数据库】【Mysql】慢SQL深度分析:EXPLAIN 与 optimizer_trace 全解析
数据库·sql·mysql
XerCis15 分钟前
PostgreSQL超全指南
数据库·postgresql
数据知道16 分钟前
万字详解模式(Schema):如何利用 Schema 实现PostgreSQL中开发/测试/生产环境隔离
数据库·postgresql
I_Jln.16 分钟前
Docker:快速构建、运行、管理应用的工具
运维·docker·容器
资料库0117 分钟前
LVS、Nginx、HAProxy核心区别是什么?
运维·nginx·lvs
WilliamHu.19 分钟前
智能体项目实战
数据库·oracle
国科安芯25 分钟前
尺寸约束下商业卫星编码器系统的抗辐照MCU性能边界研究
运维·单片机·嵌入式硬件·安全·安全威胁分析
数据知道30 分钟前
PostgreSQL实战:详细讲述UUID主键,以及如何生成无热点的分布式主键
数据库·分布式·postgresql
数据知道30 分钟前
PostgreSQL实战:如何选择合适的数据类型?
数据库·postgresql