PL/SQL的if语句的执行顺序

PL/SQL的if语句的语法定义如下:

IF condition THEN

{...statements...}

ELSIF condition THEN

{...statements...}

ELSE

{...statements...}

END IF;

由于PL/SQL不像高级语言,没有大括号,如果statements中包含了多个操作,这些操作是否都会执行呢?

下面写了一个函数做一个实验,来验证if语句的执行顺序:

<span style="font-size:18px;">create or replace function testif(v_i in number)
   return number as
begin
    if v_i<0
       then
         dbms_output.put_line('输出内容1');
         dbms_output.put_line('输出内容2');
         dbms_output.put_line('输出内容3');
    elsif v_i=1 then
         dbms_output.put_line('输出内容4');
         dbms_output.put_line('输出内容5');
    elsif v_i=2 then
         dbms_output.put_line('输出内容6');
         dbms_output.put_line('输出内容7');
    else
         dbms_output.put_line('输出内容8');
         dbms_output.put_line('输出内容9');
    end if;
    return v_i;
end testif;
</span>

如果v_i=-1时,控制台打印出:

输出内容1

输出内容2

输出内容3

如果v_i=1时,控制台打印出:

输出内容4

输出内容5

如果v_i=2时,控制台打印出:

输出内容6

输出内容7

如果v_i=3时,控制台打印出:

输出内容8

输出内容9

总结:

PL/SQL中,不需要大括号或begin..end把下面三个语句括起来,下面三个语句也会一起执行。

<span style="font-size:18px;">         dbms_output.put_line('输出内容1');
         dbms_output.put_line('输出内容2');
         dbms_output.put_line('输出内容3');</span>
时间: 2025-01-12 19:16:41

PL/SQL的if语句的执行顺序的相关文章

SQL 中 SELECT 语句的执行顺序

好像自已在书写 SQL 语句时由于不清楚各个关键字的执行顺序, 往往组织的 SQL 语句缺少很好的逻辑, 凭感觉 "拼凑" ( 不好意思, 如果您的 SQL 语句也经常 "拼凑", 那您是不是得好好反省一下呢?, 呵呵). 确实是爽了自己, 可苦了机器, 服务器还需要在我们的杂乱无章的 SQL 语句中寻找它下一句需要执行的关键字在哪里. 效率嘛, 由于我们的感觉神经对秒以下的变化实在不敏感, 暂且就认为自已写的 SQL 顺序无关紧要, "反正没什么变化!&

容易被忽略的事----sql语句中select语句的执行顺序

关于Sql中Select语句的执行顺序,一直很少注意这个问题,对于关键字的使用也很随意,至于效率问题,因为表中的数据量都不是很大,所以也不是很在意. 今天在一次面试的时候自己见到了,感觉没一点的印象,所以也就没有答上来,现在整理一下吧,希望提醒自己,也能够帮到其他的朋友.如下: (8) SELECT (9)DISTINCT (11) <TOP_specification> <select_list> (1) FROM <left_table> (3) <join_

SQL 语句的执行顺序

写在前面的话:有时不理解SQL语句各个部分执行顺序,导致理解上出现偏差,或者是书写SQL语句时随心所欲,所以有必要了解一下sql语句的执行顺序.可以有时间自己写一个简单的数据库,理解会更加深入.下面就写写我的一些理解,以SQL SERVER2008为例,进行说明. 先看下面这条简单SQL语句: 1 select 2 top 10 * 3 from Student 4 where age>20 这条SQL语句是否可以有下面两种理解呢 (1)先从Student表中选出age>20的数据,然后从这些

SQL语句的执行顺序和效率

今天上午在开发的过程中,突然遇到一个问题,需要了解SQL语句的执行顺序才能继续,上网上查了一下相关的资料,现整理如下:一.sql语句的执行步骤: 1)语法分析,分析语句的语法是否符合规范,衡量语句中各表达式的意义. 2) 语义分析,检查语句中涉及的所有数据库对象是否存在,且用户有相应的权限. 3)视图转换,将涉及视图的查询语句转换为相应的对基表查询语句. 4)表达式转换, 将复杂的 SQL 表达式转换为较简单的等效连接表达式. 5)选择优化器,不同的优化器一般产生不同的"执行计划" 6

浅谈SQL优化入门:1、SQL查询语句的执行顺序

1.SQL查询语句的执行顺序 (7) SELECT (8) DISTINCT <select_list> (1) FROM <left_table> (3) <join_type> JOIN <right_table> (2) ON <join_condition> (4) WHERE <where_condition> (5) GROUP BY <group_by_list> (6) HAVING <having_

SQL SERVER 一个SQL语句的执行顺序

原文:SQL SERVER 一个SQL语句的执行顺序 一个SQL 语句的执行顺序 1.From (告诉程序 来自哪张表  如果是表表达式 依旧是如此顺序) 2.Where(条件筛选  谓词筛选 ) 3.Group by(分组) 4.Having(分组  谓词筛选 ) 5.Select (表达式) 6.表达式(开窗函数 聚合函数 等等) 7.Distinct(去重复) 8.ORDER BY 9.TOP/OFFSET-FETCH 原文地址:https://www.cnblogs.com/lonely

通过讨论Oracle 中sql语句的执行顺序,判断哪里可以使用定义过的别名

查询语句的执行顺序: select ename as name from scott.emp emp where emp.job=' CLERK' order by name 1.先执行from 确定数据来自哪里 2.再执行where 条件 判断符合条件的数据,可以使用表scoot.emp 的别名emp 3.执行select 查询 查询数据 4.最后执行 order by 对查出来的数据排序,所以order by后可以使用字段eame的别名name 原文地址:http://blog.51cto.

T-sql语句查询执行顺序

原文:T-sql语句查询执行顺序 前言 数据库的查询执行,毋庸置疑是程序员必备技能之一,然而数据库查询执行的过程绚烂多彩,却是很少被人了解,今天哥哥要带你装逼带你飞,深入一下这sql查询的来龙去脉,为查询的性能优化处理打个基础,或许面试你也会遇到,预防不跪还是看看吧. 这篇博客,摒弃查询优化性能,作为其基础,只针对查询流程讲解剖析. 本片博客阐述的过程为 1.上一个标识过的sql语句,展示查询执行的流程 2.上一个流程图 3.做一个例子逐步深入分析,帮助理解 4.做一个装逼的总结 sql查询语句

pl/sql常用判断语句

语句一: IF-THEN IF 条件 THEN 执行语句 END IF; 语句二: IF-THEN-ELSE IF 条件 THEN 执行语句 ELSE 执行其他语句 END IF; 语句三: IF-THEN-ELSIF IF 条件1 THEN 执行语句1 ELSIF 条件2 THEN 执行语句2 ELSE 执行其他语句 END IF; pl/sql常用判断语句