zoukankan      html  css  js  c++  java
  • oracle 10G以上版本 树形查询新加的几个功能

    1.判断当前节点是否叶子节点

    在 Oracle 10g 中,还有其他更多关于层次查询的新特性 。例如,有的时候用户更关心的是每个层次分支中等级最低的内容。那么你就可以利用伪列函数CONNECT_BY_ISLEAF来判断当前行是不是叶子。如果是叶子就会在伪列中显示“1”,如果不是叶子而是一个分支(例如当前内容是其他行的父亲)就显示“0”。

    2.取当前节点的根节点。(CONNECT_BY_ROOT跟在列名前面使用)

    在Oracle 10g 中还有一个新操作――CONNECT_BY_ROOT。 它用在列名之前用于返回当前层的根节点。

    3.解决有无闭路循环的问题。

    在Oracle 10g 之前的版本中,如果在你的树中出现了环状循环(如一个孩子节点引用一个父亲节点),Oracle 就会报出一个错误提示:“ ORA-01436: CONNECT BY loop in user data”。如果不删掉对父亲的引用就无法执行查询操作。而在 Oracle 10g 中,只要指定“NOCYCLE”就可以进行任意的查询操作。与这个关键字相关的还有一个伪列――CONNECT_BY_ISCYCLE, 如果在当前行中引用了某个父亲节点的内容并在树中出现了循环,那么该行的伪列中就会显示“1”,否则就显示“0”。

    自:http://blog.itpub.net/10768286/viewspace-163530

    实战例子:

    SELECT connect_by_isleaf isyz, LEVEL cj,connect_by_root t.res_name ywmkmc, t.res_id, t.res_pid, substr(t.res_pvalue, instr(t.res_pvalue, 'MENUID=') + 7) ywmkid, t.res_order pxm, t.res_code
      FROM slwz2.app_resource t
     WHERE t.enabled = '1' AND t.area_id = 'B99E067EB3F74185954780C2710CDF7C'
     START WITH t.res_name = '发起业务' --t.res_pid = '0'
    CONNECT BY PRIOR t.res_id = t.res_pid
     ORDER SIBLINGS BY t.res_order

  • 相关阅读:
    1869六度分离
    hdu 2066 一个人的旅行
    HDU1424搬寝室
    poj 1511 Invitation Cards
    hdu 3999The order of a Tree
    hdu 2680 Choose the best route
    Hdu 3117 Fibonacci Numbers
    hdu 2962 Trucking
    钽电容黑色和黄色的区别
    ALTER FPGA通过软件设置上拉(转)
  • 原文地址:https://www.cnblogs.com/liuzhixian/p/3501962.html
Copyright © 2011-2022 走看看