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

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

相关推荐
编程小Y16 分钟前
如何优化MySQL的查询性能?
数据库·mysql
用户479492835691521 分钟前
性能提升 40 倍!实战 PostgreSQL FDW 解决微服务跨库查询难题
数据库·后端
计算机毕设VX:Fegn089537 分钟前
计算机毕业设计|基于springboot + vue宠物医院管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
贺今宵43 分钟前
安装better-sqlite3报错electron-vite
javascript·sql·sqlite·sqlite3
haimin03711 小时前
linux设置CPU固定频率
linux·运维·服务器
kimi-2221 小时前
LangChain 将数据加载到 Chroma 向量数据库
数据库·langchain
一条咸鱼¥¥¥2 小时前
【运维经验】服务器磁盘做镜像的方法
运维·服务器·windows·经验分享
渣渣盟2 小时前
NFS服务器配置全攻略:从入门到精通
linux·运维·服务器
一只旭宝2 小时前
Linux专题九:I/O复用(水平以及边缘触发放到libevent库那一专题细讲)
linux·运维·服务器
Victor3562 小时前
Hibernate(9)什么是Hibernate的Transaction?
后端