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

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

相关推荐
m0_7349497911 小时前
MySQL如何配置定时清理过期备份文件_find命令与保留周期策略
jvm·数据库·python
简单点了11 小时前
全栈编程基础知识7
运维·服务器·网络
眷蓝天11 小时前
Docker 镜像瘦身:从 GB 到 MB 的优化实践
运维·docker·容器
实心儿儿11 小时前
Linux —— 进程控制 - mini shell
linux·运维·服务器
m0_5145205711 小时前
MySQL索引优化后性能没提升_通过EXPLAIN查看索引命中率
jvm·数据库·python
NaMM CHIN12 小时前
sql实战解析-sum()over(partition by xx order by xx)
数据库·sql
2601_9498177212 小时前
Spring Boot3.3.X整合Mybatis-Plus
spring boot·后端·mybatis
不瘦80斤不改名12 小时前
深入浅出 MySQL(一):一文理清 SQL 核心规范与五大分类
数据库·sql·mysql
程序员黄老师12 小时前
Windows文件移动到Linux上的坑
linux·运维·服务器
woniu_buhui_fei12 小时前
MySQL知识整理二
数据库·mysql