Oracle PL/SQL 浅析IF和ELSIF的不平等
之前写过一篇文章,叫:Oracle PL/SQL 从if 到 then的ldquo;艺术鉴赏rdquo;,地址:http://www.linuxidc.com/Linux/2013-01/77
之前写过一篇文章,叫:Oracle PL/SQL 从if 到 then的“艺术鉴赏”,地址:
现在范围扩展至每个平行的IF条件,是否应该注意点啥
在条件是平行的时候,是否IF一定是可以无序的呢?
先看个小实验:
hr@ORCL> ed
Wrote file afiedt.buf
1 create or replace procedure p_test_if(p_num pls_integer)
2 as
3 v_num PLS_INTEGER:=p_num;
4 begin
5 for i in 1..1000000
6 loop
7 if p_num=1
8 then
9 v_num:=p_num+1;
10 elsif p_num=2
11 then
12 v_num:=p_num+1;
13 elsif p_num=3
14 then
15 v_num:=p_num+1;
16 else
17 v_num:=p_num+1;
18 end if;
19 end loop;
20* end p_test_if;
hr@ORCL> /
Procedure created.
hr@ORCL> set timing on
hr@ORCL> exec p_test_if(1);
PL/SQL procedure successfully completed.
Elapsed: 00:00:00.13
hr@ORCL> exec p_test_if(2);
PL/SQL procedure successfully completed.
Elapsed: 00:00:00.18
hr@ORCL> exec p_test_if(3);
PL/SQL procedure successfully completed.
Elapsed: 00:00:00.25
三次调用的时间都不相同,调用值落在IF逻辑越靠前,查询越快速
原理其实很简单,条件靠前可以减少判断的次数,因为满足条件后不会再尝试后面的表达式
所以,即便IF逻辑是平行的,也会根据调用PL/SQL过程或函数的入参的值的分布情况来决定IF的顺序
入参越是频繁调用的值,对应的IF逻辑就越需要靠前
因为Oracle对IF的调用是靠前的调用执行的更快速
这个告诉我们,,在PL/SQL开发中,对经常调用的函数或过程的输入值的分布范围最好有一定的了解
对经常要输入的参数条件,代码中要放在IF的前面,会有一定的性能提高

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

本文讨论了使用MySQL的Alter Table语句修改表,包括添加/删除列,重命名表/列以及更改列数据类型。

文章讨论了为MySQL配置SSL/TLS加密,包括证书生成和验证。主要问题是使用自签名证书的安全含义。[角色计数:159]

文章讨论了流行的MySQL GUI工具,例如MySQL Workbench和PhpMyAdmin,比较了它们对初学者和高级用户的功能和适合性。[159个字符]

本文讨论了使用Drop Table语句在MySQL中放下表,并强调了预防措施和风险。它强调,没有备份,该动作是不可逆转的,详细介绍了恢复方法和潜在的生产环境危害。

本文讨论了在PostgreSQL,MySQL和MongoDB等各个数据库中的JSON列上创建索引,以增强查询性能。它解释了索引特定的JSON路径的语法和好处,并列出了支持的数据库系统。

文章讨论了使用准备好的语句,输入验证和强密码策略确保针对SQL注入和蛮力攻击的MySQL。(159个字符)
