zoukankan      html  css  js  c++  java
  • oracle 函数中,一定要注意出现空记录和多条记录的处理方法

    今天折腾了3个小时,为一个以前不知道的oracle函数机制:

    在sql查询中,如果一个查询未能获取记录,oracle不会报错

    如select aa from bb where 1=2;

    但在oracle函数中,如果是赋值语句,就会报错ORA-01403: no data found 数据未找到

    如select aa into kk from bb where 1=2;

    今天的错误就在这里,主要是弄混了字段null和记录为空的null,而且是在递归调用中,sql的断点调试其实是直接进入了最后一层递归,所以第一步就报错。而用sql检查只检查出第一步有值。

    所以迷惑了半天。

    解决函数中空记录报错的方法最好是用count(*)判断,通过截获报错Exception的方法一直提示没有返回值,没找到原因

    用count(*) 时注意,sql自动进入了单分组模式,所有字段都必须用min,max等。 

    create or replace function rteseg_seq(retseg_uuid in varchar2)

    return number is

    res_seg_uuid varchar2(36); 

    begin

      select decode(count(*),1,min(rsg1.route_segment_uuid),null ) into res_seg_uuid --首先判断是否有记录,如果没有直接赋值null给变量res_seg_uuid,否则就正常赋值,注意min其实无意义,只是sql语法要求

      from ROUTE_SEGMENT_TS rsg1, ROUTE_SEGMENT_TS rsg2

      where rsg1.route_uuid = rsg2.route_uuid 

      and rsg1.end_point_id=rsg2.start_point_id 

      and rsg2.route_segment_uuid = retseg_uuid;

     

      if res_seg_uuid is null then return 1;

      else

        return rteseg_seq(res_seg_uuid)+1;

        end if;

     

    end;

  • 相关阅读:
    操作系统作业调度-操作系统
    评论--软件工程
    实验二 作业调度模拟程序
    复利计算评价博客
    构建之法(第四章读后感)
    复利计算--结对项目<04-11-2016> 1.0.0 lastest 阶段性完工~
    实验一 命令解释程序的编写
    构建之法(前三章读后感)
    实验0 了解和熟悉操作系统(操作系统)
    Scrum项目4.0
  • 原文地址:https://www.cnblogs.com/mol1995/p/7878629.html
Copyright © 2011-2022 走看看