当前位置:  数据库>oracle

Oracle PL/SQL基础 选择(IF CASE) 、 循环(LOOP WHILE FOR)

    来源: 互联网  发布时间:2017-06-03

    本文导语: 一、PL/SQL的控制结构,包括选择结构、循环结构和跳转结构 相关阅读: SQLPLUS spool 到动态日志文件名 Oracle SQLPLUS提示符设置 通过设置SQLPLUS ARRAYSIZE(行预取)加快SQL返回速度  1、选择结构 (1)IF语句 IF condition1 THEN  statement1 ;[ ELS...

一、PL/SQL的控制结构,包括选择结构、循环结构和跳转结构

相关阅读:

SQLPLUS spool 到动态日志文件名

Oracle SQLPLUS提示符设置

通过设置SQLPLUS ARRAYSIZE(行预取)加快SQL返回速度
 
1、选择结构
 
(1)IF语句

IF condition1 THEN  statement1 ;
[ ELSIF condition2 THEN statement2 ; ]
...
[ ELSE else_statements ; ]
END IF;

Attention:PL/SQL的逻辑运算结果有 TRUE 、 FALSE 、NULL 三种情况,所以在进行条件选择判断时,要考虑条件结果为NULL的情况。

Example:

create or replace procedure detector_plsql_if(
      v_control_type in varchar2)
as
    v_pre_print varchar2(100) := 'value of parameter [in] v_control_type';
begin

    if v_control_type = 'if' then
      dbms_output.put_line(v_pre_print || ' (if) :' || v_control_type);
    elsif v_control_type = 'case' then
      dbms_output.put_line(v_pre_print || ' (case) :' || v_control_type);
    elsif v_control_type is null then
      dbms_output.put_line(v_pre_print || ' (null) :' || v_control_type);
    else
      dbms_output.put_line(v_pre_print || ' :' || v_control_type);
    end if;

end detector_plsql_if;

(2)、CASE 语句

CASE语句有两种形式:一种只进行等值比较,另一种可以进行多各种条件比较。

A、只进行等值比较

CASE test_value
 WHEN value1 THEN statement1;
[ WHEN value2 THEN statement2; ]
...
[ ELSE else_statement ; ]
END CASE;

Example:

create or replace procedure detector_plsql_case(
  v_control_type in varchar2)
is
  v_pre_print varchar2(100) := 'value of parameter [in] v_control_type';
begin

    case v_control_type
      when 'if' then
          dbms_output.put_line(v_pre_print || ' (if) :' || v_control_type);
      when 'case' then
          dbms_output.put_line(v_pre_print || ' (case) :' || v_control_type);
      else
          dbms_output.put_line(v_pre_print || ' :' || v_control_type);
    end case;

end detector_plsql_case;

B、进行多种条件的比较

CASE
        WHEN condition1 THEN statement1 ;
        [ WHEN condition2 THEN statement2; ]
        ...
        [ ELSE else_statements ; ]
END CASE;

CASE语句对每一个WHEN条件进行判断,当条件为真时,执行其后面的语句;如果所有条件都不为真,则执行ELSE后的语句。

Attention:在CASE语句中,当第一个WHEN条件为真时,执行其后的操作,操作完成后结束CASE语句,其它的WHEN条件不再判断,其后的操作也不执行。

Example:

create or replace procedure detector_plsql_case2(
 v_control_type in varchar2)
as
  v_pre_print varchar2(100) := 'value of parameter [in] v_control_type';
begin

  case
    when v_control_type = 'if' then
        dbms_output.put_line(v_pre_print || ' (if) :' || v_control_type);
    when v_control_type = 'case' then
          dbms_output.put_line(v_pre_print || ' (case) :' || v_control_type);
    when v_control_type is null then
          dbms_output.put_line(v_pre_print || ' (null) :' || v_control_type);
    else
          dbms_output.put_line(v_pre_print || ' :' || v_control_type);     
  end case;

end detector_plsql_case2;

更多详情见请继续阅读下一页的精彩内容:


    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Oracle相关基础知识教程集锦
  • 基础知识:Oracle数据库的启动方式
  • Oracle虚拟桌面基础架构(VDI)3.2上市
  • Oracle SQL基础知识
  • 基于Oracle的面向对象技术入门基础简析开发者网络Oracle
  • Oracle DDL,DML,DCL,TCL 基础概念
  • 解析学习Oracle架构所应了解的基础知识
  • Linux下OCI基础:配置Instant Client连Oracle数据库
  • Oracle PL/SQL语言入门基础
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • Oracle 数据库开发工具 Oracle SQL Developer
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • Oracle EBS R12 支持 Oracle Database 11g
  • Oracle 10g和Oracle 11g网格技术介绍
  • SCO unix下安装oracle,但没有光盘,请大家推荐一个oracle下载站点(unix版本的)。谢谢!!!!
  • oracle中如何把表中具有相同值列的多行数据合并成一行
  • 请问大家用oracle数据库, 用import oracle.*;下的东西么? 还是用标准库?
  • Oracle 数据库(oracle Database)性能调优技术详解
  • Linux /$ORACLE_HOME $ORACLE_HOME
  • ORACLE日期相关操作
  • Linux系统下Oracle的启动与Oracle监听的启动
  • ORACLE数据库常用字段数据类型介绍
  • 请问在solaris下安装ORACLE,用root用户和用oracle用户安装有什么区别么?
  • Oracle 12c的九大最新技术特性介绍
  • 网间Oracle的连接,远程连接Oracle服务器??


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,