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

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

相关推荐
CodeJourney.21 分钟前
基于DeepSeek与HTML的可视化图表创新研究
数据库·人工智能·信息可视化·excel
kngines27 分钟前
【PostgreSQL数据分析实战:从数据清洗到可视化全流程】3.3 异常值识别(Z-score法/IQR法/业务规则法)
数据库·postgresql·数据分析·z-score法·iqr法·业务规则法
王嘉俊92537 分钟前
一条 SQL 查询语句是如何执行的(MySQL)
数据库·sql·mysql
cooldream20091 小时前
深入理解 Redis 的主从、哨兵与集群架构
数据库·redis·架构·系统架构师
blackA_1 小时前
数据库MySQL学习——day8(复习与巩固基础知识)
数据库·学习·mysql
magic 2452 小时前
SpringMVC——第三章:获取请求数据
java·数据库·springmvc
偶尔微微一笑2 小时前
postgresql数据库基本操作
运维·数据库·postgresql·oracle
o不ok!2 小时前
实验4 mySQL查询和视图
数据库·mysql·oracle
有时间要学习2 小时前
MySQL——数据库基础&&操作
数据库·mysql
临界点oc3 小时前
Redis从入门到实战——实战篇(下)
数据库·redis·缓存