Oracle 递归的写法(start with) 以及where条件作用域

本文探讨了Oracle数据库中使用START WITH和CONNECT BY进行递归查询时,WHERE条件的实际作用范围。当WHERE条件在递归过程中错误地被理解为对每个递归步骤生效时,可能导致无法预期的错误,如ORA-01436异常。通过修正WHERE条件的位置,确保其在递归结束后过滤结果,可以解决因数据循环导致的问题。
摘要由CSDN通过智能技术生成

先转一个讲Oracle递归讲得非常透彻的文章: http://blog.csdn.net/weiwenhp/article/details/8218091

前言:嗯,这也是一个前人挖坑,后人来填的故事。

        数据库里有一个关于地域信息的表,可以叫它tableA,此表里有三个字段分别是 parent_area_code、area_code、isvalid,

        有一段sql的功能是查找指定地域code的所有父类地域,sql如下,这是一个典型的递归的写法:

      

        select area_code
        from tableA
        where isvalid=1
        start with area_code =
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值