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.parent = a.children START WITH a.children ='1040101' --父取子 select * from tb_cus_area_cde a CONNECT BY PRIOR a.children =a.parent START WITH a.parent 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中的数据