主页 > 知识库 > Oracle实现行转换成列的方法

Oracle实现行转换成列的方法

热门标签:呼叫中心市场需求 地方门户网站 百度竞价排名 AI电销 网站排名优化 服务外包 铁路电话系统 Linux服务器

本文实例讲述了Oracle实现行转换成列的方法。分享给大家供大家参考,具体如下:

把行转成列 把学生表,成绩表,班级表,学科表 合并成一张成绩表效果如下:

创建表

--班级表
create table CLASS
(
 ID    VARCHAR2(5) not null primary key,
 CLASSNAME VARCHAR2(10)
);
--学生表
create table STUDENT
(
 ID   VARCHAR2(10) not null primary key,
 NAME  VARCHAR2(10),
 AGE   NUMBER(3),
 CLASSID VARCHAR2(5)
);
--科目表
create table subject(
id varchar2(10) primary key,
subname varchar2(10)
);
--分数表
 create table score(
 sid varchar2(4),
 subid varchar2(10),
 score number(4,1)
);

查询sql 如下

select s1.name 姓名,
    s1.age 年龄,
    s1.classname 班级,
    score_.sid,
    数学,
    语文,
    物理,
    化学,
    (数学 + 语文 + 物理 + 化学) 总分
 from (select s.sid,
        sum(decode(s.subid, 'SUB001', s.score)) 数学,
        sum(decode(s.subid, 'SUB002', s.score)) 语文,
        sum(decode(s.subid, 'SUB003', s.score)) 物理,
        sum(decode(s.subid,'SUB004',s.score)) 化学
     from score s
     group by s.sid) score_
 right join (select st.id, st.name, st.age, c.classname
        from student st, class c
       where c.id = st.classid) s1 on s1.id = score_.sid
 order by 总分;

更多关于Oracle相关内容感兴趣的读者可查看本站专题:《Oracle常用函数汇总》、《Oracle日期与时间操作技巧总结》及《php+Oracle数据库程序设计技巧总结》

希望本文所述对大家Oracle数据库程序设计有所帮助。

您可能感兴趣的文章:
  • Oracle实现行列转换的方法分析
  • Oracle的数据表中行转列与列转行的操作实例讲解
  • Oracle 数据库针对表主键列并发导致行级锁简单演示
  • oracle wm_concat 列转行 逗号分隔
  • Oracle逗号分隔列转行实现方法
  • 从Oracle 表格行列转置说起
  • Oracle CBO几种基本的查询转换详解
  • oracle中to_date详细用法示例(oracle日期格式转换)
  • 通过创建SQLServer 2005到 Oracle10g 的链接服务器实现异构数据库数据转换方案
  • MySQL转换Oracle的需要注意的七个事项
  • 将mysql转换到oracle必须了解的50件事
  • ORACLE常用数值函数、转换函数、字符串函数

标签:兰州 铜川 衡水 崇左 湘潭 湖南 仙桃 黄山

巨人网络通讯声明:本文标题《Oracle实现行转换成列的方法》,本文关键词  ;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 收缩
    • 微信客服
    • 微信二维码
    • 电话咨询

    • 400-1100-266