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

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

相关推荐
用户47949283569157 分钟前
claude Fable用不了?把Gpt 5.5pro接到你的claude code里
前端·后端
GetcharZp2 小时前
告别 Nginx 复杂配置!这款带 Web 面板的万能代理神器,让端口转发变得如此简单
后端
IT_陈寒4 小时前
React的useState居然还有这种坑?我差点删库跑路
前端·人工智能·后端
Pedantic5 小时前
SwiftUI 手势笔记
前端·后端
金銀銅鐵5 小时前
[Python] 从《千字文》中随机挑选汉字
后端·python
用户0328472220706 小时前
如何搭建本地yum源(上)
运维
飘尘8 小时前
前端转型全栈(Java后端)的快速上手指引
前端·后端·全栈
浏览器工程师9 小时前
AI Agent 接浏览器任务,先别让它一路点到底
前端·后端
行者全栈架构师9 小时前
Maven dependency:tree 的 8 个高级用法
java·后端