CONNECT BY 是sql内部建立递归查询的方式,该方法在层级查询以及 ROWNUM|LEVEL是同理,都是递归到最后限定的值or ROWNUM|LEVEL。
create table t(id varchar2(1));
insert into t(id) values ('a');
insert into t(id) values ('b');
insert into t(id) values ('c');
1.例子
select level , id from t connect by level < 3;
CONNECT BY level < 3 限定了sql中递归的层级数,一共有2层层级,第一层列出 a,b,c; 第二层 在第一层a的下面列出a,b,c,
在第一层b的下面列出a,b,c…以此类推,直至第二层列出所有第一层中 a,b,c下的a,b,c。 完成递归。
select rownum , id from t connect by rownum < 4;
CONNECT BY ROWNUM (简单递归)例中CONNECT BY rownum <4, 即只递归第一个字符a,使其伪列达到规定边界CONNECT BY rownum <4 , 后再列出剩余字符(剩余字符b,c不受限定影响)。