博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ORACLE查询树型关系(connect by prior start with) .
阅读量:4196 次
发布时间:2019-05-26

本文共 965 字,大约阅读时间需要 3 分钟。

connect by prior start with 经常会被用到一个表中存在递归关系的时候。比如我们经常会将一个比较复杂的目录树存储到一个表中。或者将一些部门存储到一个表中,而这些部门互相有隶属关系。这个时候你就会用到connect by prior start with。

典型的使用方法就是:

select * from table connect by prior cur_id=parent_id start with cur_id=???
例如:
a            b
1           0
2           1
3           1
4           2
5           3

如果想查找a=2及其下面的所有数据,则:

select * from table connect by prior a=b start with a=2
a           b
2           1
4           2

这些只是基础,皮毛。其实只要你灵活的构造查询语句。可以得出意想不到的结果。比如生成树每一个路径。

但是这些记录组成的树必须正常才可以。如果有互为父子的情况,就会出现循环错误!

select * from tb_cus_area_cde

--子取父

select * from tb_cus_area_cde a    
CONNECT BY PRIOR     a.c_snr_area=a.c_area_cde START WITH a.c_area_cde='1040101'

--父取子

select * from tb_cus_area_cde a    
CONNECT BY PRIOR     a.c_area_cde=a.c_snr_area START WITH a.c_snr_area is null

 

 

注意:在用这个函数的时候,statement的参数要用 ResultSet.TYPE_SCROLL_INSENSITIVE   而不能用 ResultSet.TYPE_SCROLL_SENSITIVE,在这里再把这两个之间的区别讲讲:

1.TYPE_FORWORD_ONLY,只可向前滚动;   

    
2.TYPE_SCROLL_INSENSITIVE,双向滚动,但不及时更新,就是如果数据库里的数据修改过,并不在ResultSet中反应出来。   
    
3.TYPE_SCROLL_SENSITIVE,双向滚动,并及时跟踪数据库的更新,以便更改ResultSet中的数据。    

转载地址:http://wkkli.baihongyu.com/

你可能感兴趣的文章
实时内存数据库的数据管理
查看>>
Sonar代码质量管理平台
查看>>
Checkstyle, PMD, Findbugs对比
查看>>
网站成功的三十三个法则
查看>>
Memcache基础教程
查看>>
程序员能力矩阵
查看>>
主流浏览器内核概览
查看>>
交大研究生,就一个字牛
查看>>
Android开发之ADB使用
查看>>
Android模拟器使用模拟SD卡
查看>>
Redis入门教程
查看>>
Google code上利用SVN托管代码
查看>>
技术的发展与互联网的发展
查看>>
工作流简介
查看>>
软件项目管理实践之日计划
查看>>
浅析大型网站的架构
查看>>
电脑故障排除经验
查看>>
数据库升级脚本制作
查看>>
HTTP response splitting 攻击
查看>>
Google十三年
查看>>