欢迎来到天天文库
浏览记录
ID:42596316
大小:19.73 KB
页数:6页
时间:2019-09-18
《Oracle树查询》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、Oracle树查询(2011-12-2710:07:27)转载▼标签:select...startwith...connectby...prior杂谈分类:Orcale Oracle树查询的最重要的就是select...startwith...connectby...prior语法了。依托于该语法,我们可以将一个表形结构的中以树的顺序列出来。在下面列述了Oracle中树型查询的常用查询方式以及经常使用的与树查询相关的Oracle特性函数等,在这里只涉及到一张表中的树查询方式而不涉及多表中的关联等。 以我做过的一个项目中的表为例,表结构如下:Sq
2、l代码1. CREATETABLEFLFL 2. ( 3. ID NUMBER NOTNULL, 4. MC NVARCHAR2(20), 5. FLJB NUMBER, 6. SJFLID NUMBER 7. ) CREATETABLEFLFL(IDNUMBERNOTNULL,MCNVARCHAR2(20),FLJBNUMBER,SJFLIDNUMBER) FLJB是作为树的级别,在
3、很多查询中可以加快SQL的查询效率。在下面演示的功能基本上不使用这个关键字。 SJFLID存储的是上级ID,如果是顶级父节点,该SJFLID为null(得补充一句,当初的确是这样设计的,不过现在知道,表中最好别有null记录,这会引起全文扫描,建议改成0代替)。 我们从最基本的操作,逐步列出树查询中常见的操作,所以查询出来的节点以家族中的辈份作比方。 1.查找树中的所有顶级父节点(辈份最长的人)。假设这个树是个目录结构,那么第一个操作总是找出所有的顶级节点,再根据该节点找到其下属节点。Sql代码1. SELECT*FROM
4、flflWHEREsjflidISNULL; SELECT*FROMflflWHEREsjflidISNULL; 这是个引子,没用到树型查询。 2.查找一个节点的直属子节点(所有儿子)。如果查找的是直属子类节点,也是不用用到树型查询的。Sql代码1. SELECT*FROMflflWHEREsjflid=819459; SELECT*FROMflflWHEREsjflid=819459; 这个可以找到ID为819459的直属子类节点。 3.查找一个节点的所有直属子节点(所有后代)。Sql代码1. SELE
5、CT*FROMflflSTARTWITHID=819459CONNECTBYsjflid=PRIORID; SELECT*FROMflflSTARTWITHID=819459CONNECTBYsjflid=PRIORID; 这个查找的是ID为819459的节点下的所有直属子类节点,包括子辈的和孙子辈的所有直属节点。 4.查找一个节点的直属父节点(父亲)。如果查找的是节点的直属父节点,也是不用用到树型查询的。Sql代码1. SELECTb.*FROMflflaJOINflflbONa.sjflid=b.IDWHEREa.ID=67
6、58; SELECTb.*FROMflflaJOINflflbONa.sjflid=b.IDWHEREa.ID=6758; 这个找到的是ID为6758的节点的直属父节点,要用到同一张表的关联了。 5.查找一个节点的所有直属父节点(祖宗)。Sql代码1. SELECT*FROMflflSTARTWITHID=6758CONNECTBYPRIORsjflid=ID; SELECT*FROMflflSTARTWITHID=6758CONNECTBYPRIORsjflid=ID; 这里查找的就是ID为6758的所有直属父节点,
7、打个比方就是找到一个人的父亲、祖父等。但是值得注意的是这个查询出来的结果的顺序是先列出子类节点再列出父类节点,姑且认为是个倒序吧。 上面列出两个树型查询方式,第3条语句和第5条语句,这两条语句之间的区别在于prior关键字的位置不同,所以决定了查询的方式不同。当sjflid=PRIORID时,数据库会根据当前的ID迭代出sjflid与该ID相同的记录,所以查询的结果是迭代出了所有的子类记录;而PRIORID=sjflid时,数据库会跟据当前的sjflid来迭代出与当前的sjflid相同的id的记录,所以查询出来的结果就是所有的父类结果。
8、 以下是一系列针对树结构的更深层次的查询,这里的查询不一定是最优的查询方式,或许只是其中的一种
此文档下载收益归作者所有