暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

Oracle 条件语句

askTom 2017-05-19
192

问题描述

我想根据参考光标内的if/else条件获取结果集?....是否有可能这样做,或者有其他选择?

专家解答

只需根据条件为ref游标打开不同的SQL,例如:

SQL> set serverout on
SQL> declare
  2    rc sys_refcursor;
  3  begin
  4    if to_char(sysdate,'SS') < 30 then
  5       dbms_output.put_line('First half of minute - we go get SYS');
  6       open rc for select * from dba_tables where owner = 'SYS';
  7    else
  8       dbms_output.put_line('Second half of minute - we go get SCOTT');
  9       open rc for select * from dba_tables where owner = 'SCOTT';
 10    end if;
 11  end;
 12  /
Second half of minute - we go get SCOTT

PL/SQL procedure successfully completed.

SQL>
SQL> /
First half of minute - we go get SYS

PL/SQL procedure successfully completed.
复制


「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论