当前位置:  数据库>oracle

Oracle Connect By 使用实例

    来源: 互联网  发布时间:2017-06-04

    本文导语: 在实际开发中  connect by可以替代plsql或java中的循环间化开发代码,提高开发效率。如下是我在工作中遇到一个实际解决的问题 Oracle CONNECT BY的用法  Oracle递归START WITH...CONNECT BY PRIOR子句用法 Oracle 有表连接的connect by 的优化 Orac...

在实际开发中  connect by可以替代plsql或java中的循环间化开发代码,提高开发效率。如下是我在工作中遇到一个实际解决的问题

Oracle CONNECT BY的用法 

Oracle递归START WITH...CONNECT BY PRIOR子句用法

Oracle 有表连接的connect by 的优化

Oracle 树查询 性能优化纪实(start with, connect by)

Oracle Database 10g 中新的 CONNECT BY 特性

具体场景:

原系统是一个管理宿舍信息的系统,dorm_room用于存放宿舍的房间信息具体表结构是
 create table dorm_room(bno varchar2(2),fno varchar2(2),rno varchar2(2),bednum varchar2(2));
 这里存放了楼栋号,层号,房间号,及房间中床位总数
 具体数据如下
 insert into dorm_room values(1,1,1,4);
 insert into dorm_room values(1,1,2,4);
 insert into dorm_room values(1,1,3,7);
 也就是说有三个房间,前两个房间床位数都是4,最后一个房间的床位数是7
 目前的需求是根据床位数显示出每个房间中所有床位的数据。期望结果是
 1  1  1  1
 1  1  1  2
 1  1  1  3
 1  1  1  4
 1  1  2  1
 1  1  2  2
 1  1  2  3
 1  1  2  4
 1  1  3  1
 1  1  3  2
 1  1  3  3
 1  1  3  4
1  1  3  5
 1  1  3  6
 1  1  3  7

如果用pl/sql根据每行的床位数判断循环次数,显示出每个房间的所有床位数,编写起来必然要书写较多行代码,因此选用
 sql中的connect by的方式生成出所有的房间的床位数,具体sql为

select distinct bno,fno,rno,t.l
 from (
 select row_number()over(partition by bno,fno,rno order by level) rn,
        bno,fno,rno,level l
 from dorm_room
 connect by level


    
 
 

您可能感兴趣的文章:

  • Linux上建立第二个ORACLE实例分析
  • Linux操作系统下Oracle数据库多实例启动方式及修改内存
  • oracle的存储过程实例讲解
  • linux redhat5.6安装oracle11g在自动创建实例时停住不动,有图
  • oracle分页存储过程 oracle存储过程实例
  • C#连接Oracle数据库的实例方法
  • Oracle数据库实例两则
  • Oracle 删除归档日志实例
  • Oracle 10g for solaris准备工作和实例的删除
  • Oracle 11G 无法连接到数据库实例故障排除
  • Linux下设置Oracle 10g 服务以及实例自动启动
  • oracle group by语句实例测试
  • Oracle数据库异构服务原理及实例说明
  • Linux下删除Oracle实例
  • 与Oracle RAC相关的连接配置写法实例
  • Oracle监听器Server端与Client端配置实例
  • Oracle中使用触发器(trigger)和序列(sequence)模拟实现自增列实例
  • oracle删除已存在的表的实例
  • CSS属性参考手册 iis7站长之家
  • Oracle数据库安全性管理基本措施实例解析
  • Oracle Connect to Idle Instance解决方法
  • Oracle内置角色connect与resource的权限
  • Oracle中的Connect/session和process的区别及关系介绍
  • oracle sys_connect_by_path 函数 结果集连接
  • Oracle中start with...connect by prior子句用法
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • linux下安装oracle后使用命令行启动的方法 linux启动oracle
  • Oracle9i 9.0.1的JDBC Drivers 可以给Oracle 8.0.5使用马?
  • Suse linux使用oracle问题
  • 请问:在使用oracle数据库作开发时,是使用pro*c作开发好些,还是使用库函数如oci等好一些啊?或者它们有什么区别或者优缺点啊?
  • jbuilder中使用oracle的问题
  • 求redhat linux 9.0下可以使用的oracle 10g或9i,还有redhat linux 9.0下可以使用的eclipse下载地址
  • Oracle事务!使用游标提交过程
  • 在Jbuilder7下,使用DbPilot.exe连接oracle,报错!请教高手!
  • AIX 64位系统上如何使用32位OCI oracle driver
  • Oracle中SQL语句连接字符串的符号使用介绍
  • 使用X manager连接oracle数据库的步骤
  • C++使用OCCI连Oracle10g的错误
  • 使用工具 plsqldev将Excel导入Oracle数据库
  • Linux下Oracle的sqlplus使用光标上下左右方法
  • Oracle 数据 使用游标
  • oracle使用sql脚本生成csv文件案例学习
  • ORACLE 修改表结构 之ALTER CONSTAINTS的使用
  • Linux中Oracle使用相关知识集锦
  • Oracle密码文件的使用和维护第1/3页
  • Oracle 触发器的使用小结
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • Oracle 数据库开发工具 Oracle SQL Developer
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • Oracle EBS R12 支持 Oracle Database 11g
  • Oracle 10g和Oracle 11g网格技术介绍


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,