• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    Oracle实现行转换成列的方法

    本文实例讲述了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数据库中的数据写入Excel
    下一篇:详解oracle 日期格式(总结)
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    Oracle实现行转换成列的方法 Oracle,实,现行,转换,成列,