首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Oracle 中的树查询和 connect by

Oracle 中的树查询和 connect by

作者头像
用户1148526
发布2018-01-03 11:56:36
发布2018-01-03 11:56:36
1.6K0
举报
文章被收录于专栏:Hadoop数据仓库Hadoop数据仓库
  • Oracle 中的树查询和 connect by 使用 connect by 和 start with 来建立类似于树的报表并不难,只要遵循以下基本原则即可: 使用 connect by 时各子句的顺序应为: select from where start with connect by order by
  • prior 使报表的顺序为从根到叶(如果 prior 列是父辈)或从叶到根(如果 prior 列是后代)。
  • where 子句可以从树中排除个体,但不排除它们的子孙(或者祖先,如果 prior 列是后代)。
  • connect by 中的条件(尤其是不等于)消除个体和它所有的子孙(或祖先,依赖于怎样跟踪树)。
  • connect by 不能与 where 子句中的表连接在一起使用。

下面是几个例子

1. 从根到叶遍历 SELECT n_parendid, n_name, (LEVEL - 1), n_id FROM navigation WHERE n_parendid IS NOT NULL START WITH n_id = 0 CONNECT BY n_parendid = PRIOR n_id; 2. 从叶到根遍历 SELECT n_parendid, n_name, (LEVEL - 1), n_id FROM navigation WHERE n_parendid IS NOT NULL START WITH n_id = 300 CONNECT BY n_id = PRIOR n_parendid; 3. 排除个体,但不排除它们的子孙 SELECT n_parendid, n_name, (LEVEL - 1), n_id FROM navigation WHERE n_parendid IS NOT NULL AND n_id != 2 START WITH n_id = 0 CONNECT BY n_parendid = PRIOR n_id; 4. 消除个体和它所有的子孙 SELECT n_parendid, n_name, (LEVEL - 1), n_id FROM navigation WHERE n_parendid IS NOT NULL START WITH n_id = 0 CONNECT BY n_parendid = PRIOR n_id AND n_id != 2; 5. 改变显示顺序 SELECT n_parendid, n_name, (LEVEL - 1), n_id FROM navigation WHERE n_parendid IS NOT NULL START WITH n_id = 0 CONNECT BY n_parendid = PRIOR n_id ORDER BY n_viewnum DESC;

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2016年12月29日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档