• 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

  • 相关阅读:
    Java设计模式之代理模式
    Java设计模式之单例模式
    Android 退出多Activity的application的方式
    自己动手系列——实现一个简单的LinkedList
    自己动手系列——实现一个简单的ArrayList
    Java多线程基础——Lock类
    制作一个功能丰富的Android天气App
    IdentityServer4 学习二
    IdentityServer4 学习一
    SC创建服务编写bat脚本
  • 原文地址:https://www.cnblogs.com/liuzhixian/p/3501962.html
Copyright © 2020-2023  润新知