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

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

相关推荐
你想考研啊4 小时前
win11安装mysql
数据库·mysql
Wpa.wk4 小时前
Docker - 搭建镜像仓库- 了解
运维·经验分享·测试工具·docker·容器
Gary董4 小时前
mysql全面优化从哪几方面入手
数据库·mysql
松涛和鸣4 小时前
66、SPI驱动ADXL345加速度计
linux·运维·单片机·嵌入式硬件·ubuntu
陌上丨4 小时前
深入理解Redis线程模型
数据库·redis·缓存
2501_948120154 小时前
数据库分布式锁在并发控制中的应用
数据库·分布式
自己的九又四分之三站台4 小时前
PGVector 详解:PostgreSQL 世界里的向量能力插件
数据库·postgresql
Humbunklung4 小时前
记一次MySQL数据库备份与SQL格式内容导出导入
数据库·sql·mysql
Remember_9934 小时前
【LeetCode精选算法】位运算专题
java·开发语言·jvm·后端·算法·leetcode
源代码•宸4 小时前
Leetcode—102. 二叉树的层序遍历【中等】
经验分享·后端·算法·leetcode·职场和发展·golang·slice