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

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

相关推荐
仙柒4155 小时前
Docker原理
运维·docker·容器
ltl8 小时前
Transformer 整体架构:一张图看懂
后端
ltl8 小时前
Decoder 详解:为什么它天生适合生成
后端
ltl8 小时前
Encoder 详解:6 层堆叠到底在做什么
后端
程序员cxuan8 小时前
微信读书官方发了 skills,把我给秀麻了。
人工智能·后端·程序员
2301_781571428 小时前
Golang格式化输出占位符都有什么_Golang fmt占位符教程【通俗】
jvm·数据库·python
养肥胖虎8 小时前
RAG学习笔记(3):区分数据库检索与RAG的使用场景
数据库·ai·rag
_ku_ku_9 小时前
数据库系统原理 · 数据库应用开发 · 自学总结
数据库
未若君雅裁9 小时前
Spring AOP、日志切面与声明式事务原理
java·后端·spring
zhangxingchao9 小时前
AI应用开发六:企业知识库
前端·人工智能·后端