Oracle 行转列两种方法
1.新建一个名为TEST表
create table TEST(
STUDENT varchar2(20),
COURSE varchar2(20),
SCORE number
);
INSERT INTO TEST(STUDENT,COURSE,SCORE) values( '张三','语文',78);
INSERT INTO TEST(STUDENT,COURSE,SCORE) values ('张三','数学',87 );
INSERT INTO TEST(STUDENT,COURSE,SCORE) values ('张三','英语',82 );
INSERT INTO TEST(STUDENT,COURSE,SCORE) values ('张三','物理',90 );
INSERT INTO TEST(STUDENT,COURSE,SCORE) values( '李四','语文',65 );
INSERT INTO TEST(STUDENT,COURSE,SCORE) values( '李四','数学',77 );
INSERT INTO TEST(STUDENT,COURSE,SCORE) values ('李四','英语',65 );
INSERT INTO TEST(STUDENT,COURSE,SCORE) values( '李四','物理',85 );
commit;
表数据如下:
3.列转行
方法··1:
select
Student,
decode(Course, '数学', Score) 数学,
decode(Course, '物理', Score) 物理,
decode(Course, '英语', Score) 英语,
decode(Course, '语文', Score) 语文
from TEST;
group by分组 后,可以用sum(),max(),min(),avg()等。

select
Student,
sum(decode(Course, '数学', Score)) 数学,
sum(decode(Course, '物理', Score)) 物理,
sum(decode(Course, '英语', Score)) 英语,
sum(decode(Course, '语文', Score)) 语文
from
TEST
group by Student
方法··2:
select
Student,
sum(case Course when '数学' then Score else null end) 数学,
sum(case Course when '物理' then Score else null end) 物理,
sum(case Course when '英语' then Score else null end) 英语,
sum(case Course when '语文' then Score else null end) 语文
from
TEST
group by Student
效果如下:
注:sum是求和的意思;比如说里面记录里面有两条张三,列转行显示的结果就会是两个张三的结果之和。
4.case when 嵌套case when 。

5.case when then else end 的几种用法。
1、简单的case when语句:
case sex when ’1' then '男' when ’2’ then '女’else ’其他’ end
2、复杂的case when语句:
case when month in (01,02,03) then '第一季度' when month in (04,05,06) then '第二季度' when month in (07,08,09) then '第三季度' when month in (10,11,12) then ‘第四季度’ end
值得注意的是,语句只返回第一个符合条件的值,剩下的case部分将会被自动忽略。
3. case sex when months between 444 and 1111 then 'XX' when months between 2222 and 9650 then 'XX’else ’其他’ end
4.select student,course, case when score >= 90 then '优秀'when score >=60 and score <90 then '良好' else '不及格' end as "成绩" from system.test ;
5.case when 与decode的差别就是 ,decode 就是 取等于的值 ,case when 还可以去区间范围的值。
来自:https://blog.csdn.net/rlhua/article/details/24668755
Oracle 行转列两种方法的更多相关文章
- 移动oracle数据文件的两种方法
1.alter database方法该方法,可以移动任何表空间的数据文件. ***关闭数据库***SQL> shutdown immediateDatabase closed.Database ...
- Sql将一列数据拆分为多行显示的两种方法
原始数据与期望结果有表tb, 如下:id value----------- -----------1 aa,bb2 aaa,bbb,ccc欲按 ...
- RAC时间同步的两种方法
集群时间同步服务在集群中的两个 Oracle RAC 节点上执行以下集群时间同步服务配置.Oracle Clusterware 11g 第 2 版及更高版本要求在部署了 Oracle RAC 的集群的 ...
- 【转】oracle 中随机取一条记录的两种方法
oracle 中随机取一条记录的两种方法 V_COUNT INT:=0; V_NUM INT :=0; 1:TBL_MYTABLE 表中要有一个值连续且唯一的列FID BEGIN SELECT COU ...
- Python 使用 xlwings 往 excel中写入一列数据的两种方法
1.准备一个二维列表,然后再range后面不指定任何选项,可以输出该二维列表中数据在一列中显示,如下代码: # -*- coding:utf-8 -*- import xlwings as xw li ...
- Oracle中spool命令实现的两种方法比较
---恢复内容开始--- 要输出符合要求格式的数据文件只需在select时用字符连接来规范格式.比如有如下表 SQL>; select id,username,password from myu ...
- PyQt(Python+Qt)学习随笔:QTableWidget中表格各列平均分配宽度的两种方法
老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 在QTableWidget表格部件中,如果需要实现表格中各列要占满部件中的可用空间,同时实现各列平分 ...
- oracle rename数据文件的两种方法
oracle rename数据文件的两种方法 2012-12-11 20:44 10925人阅读 评论(0) 收藏 举报 分类: oracle(98) 版权声明:本文为博主原创文章,未经博主允许不 ...
- CSS多行文字垂直居中的两种方法
之前写过一篇关于:CSS左右居中对齐的文章,里面提到的两种方法其实也可以引申为垂直居中对齐.写这篇文章是因为要兼容IE6.IE7的问题,我们都知道一行文字时可以通过line-height来设置垂直居中 ...
随机推荐
- JS常用的设计模式(2)——简单工厂模式
简单工厂模式是由一个方法来决定到底要创建哪个类的实例, 而这些实例经常都拥有相同的接口. 这种模式主要用在所实例化的类型在编译期并不能确定, 而是在执行期决定的情况. 说的通俗点,就像公司茶水间的饮料 ...
- [转]How to use IHttpContextAccessor in static class to set cookies
本文转自:http://stackoverflow.com/questions/37329354/how-to-use-ihttpcontextaccessor-in-static-class-to- ...
- Unity 基础
Unity 基础是unity入门的关键.他将讲解Unity的界面, 菜单项,使用资源,创设场景,并发布版本. 当你读完这段,你将理解unity是怎么工作的,如何有效地使用它,并且完成一个基本的游戏. ...
- java 判断图片的类型
// 这种方法如果遇到不是图片类型的文件会reader抛异常! public static void main(String[] args) throws IOException { // get i ...
- 详解WebApp与Native App的区别
一篇真的很棒关于html5的Web App与Native App的技术分析 ! 自Iphone和Android这两个牛逼的手机操作系统发布以来,在互联网界从此就多了一个新的名词-WebApp(意为基于 ...
- iDempiere 使用指南 使用MRP进行生产及采购排程
Created by 蓝色布鲁斯,QQ32876341,blog http://www.cnblogs.com/zzyan/ iDempiere官方中文wiki主页 http://wiki.idemp ...
- 如何取消IntelliJ IDEA打开默认项目配置
一.前言 在前端中,个人比较喜欢使用IntelliJ IDEA开发工具!IntelliJ IDEA是非常强大的开发集成工具,打开IntelliJ IDEA软件默认会打开最近一次的 ...
- all-to-mqtt
- Js 对象数组,转化为字符串
var str = [{"cuid":"23910","content":"是","type":&q ...
- TP5.0:新建控制器
例如,我们在admin模块下创建一个名为OneMenu.php的控制器 1.在该控制器文件中内容为: 2.访问的URL为:http://localhost/tp5/public/index.php/a ...