首页 / 更多教程 / Sql的行列(纵横表)转换
Sql的行列(纵横表)转换
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了Sql的行列(纵横表)转换,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2165字,纯文字阅读大概需要4分钟。
内容图文
姓名 from scores group by 姓名结果:
分析:
- 我们先拿到语文这个科目的分数。既然我们用到了group by 语句,这里肯定要用聚合函数来求分数。
- 而且我们只需要语文这一科的成绩,分组出来的 一共有 3列 ,分别是 语文、数学、物理 。 那么就需要判断科目来取分数。
这里符合我们需求的 case 语句就登场了。它和c#中switch-case 作用一样。
sql case 语句语法:
case 字段 when 值1 then 结果 when 值2 then 结果2 ... else 默认结果 end
select 姓名,SUM(case 课程 when ‘语文‘ then 分数 else 0 end) as 语文 from scores group by 姓名
结果:
既然语文的分数取到了,其他科目改变下条件就可以了。
完整的sql:
select 姓名, SUM(case 课程 when ‘语文‘ then 分数 else 0 end) as 语文, SUM(case 课程 when ‘数学‘ then 分数 else 0 end) as 数学, SUM(case 课程 when ‘物理‘ then 分数 else 0 end) as 物理 from scores group by 姓名
横表转纵表
我们先把刚刚转好的表,插入一个新表Scores2中。
select 姓名, SUM(case 课程 when ‘语文‘ then 分数 else 0 end) as 语文, SUM(case 课程 when ‘数学‘ then 分数 else 0 end) as 数学, SUM(case 课程 when ‘物理‘ then 分数 else 0 end) as 物理 into scores2 from scores group by 姓名
我们也先把张三和李四的语文成绩查出来。
select 姓名, ‘语文‘ as 课程, 语文 as 分数 from scores2
结果:
还有两科的数据怎么办呢? 很简单,我们一个个都查出来,然后用 union all 把他们组合为一张表就可以了。
select 姓名, ‘语文‘ as 课程, 语文 as 分数 from scores2 union all select 姓名, ‘数学‘ as 课程, 数学 as 分数 from scores2 union all select 姓名, ‘物理‘ as 课程, 物理 as 分数 from scores2 order by 姓名 desc
结果:
但是大家有没有觉得很麻烦呢?别急,我们有更简单的办法。下面为大家介绍pivot关系运算符。
pivot是sql server 2005 提供的运算符,所以只要数据库在05版本以上的都可以使用。主要用于行和列的转换。
pivot纵表转横表
select t2.姓名, t2.数学, t2.物理, t2.语文 from Scores as t1 pivot (sum(分数) for 课程 in(数学,语文,物理)) as t2
pivot将原来表中 课程字段中的 数据行 数学,语文,物理 转换为列,并用sum取对应列的值。
我们只需要记住它的用法就可以了。
unpivot 横表转纵表
select * from scores2 unpivot (分数 for 课程 in (语文,数学,物理)) as t3
unpivot 将 语文,数学,物理 列转为行,分数为新的一列存放对应的值。
Sql的行列(纵横表)转换
标签:
本文系统来源:http://www.cnblogs.com/janneystory/p/5622142.html
内容总结
以上是互联网集市为您收集整理的Sql的行列(纵横表)转换全部内容,希望文章能够帮你解决Sql的行列(纵横表)转换所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。