PL/SQL运算符

运算符是一个符号,告诉编译器执行特定的数学或逻辑操作。 PL/SQL语言有丰富的内置运算符,运算符提供的以下几种类型:

  • 算术运算符

  • 关系运算符

  • 比较运算符

  • 逻辑运算符

  • 字符串运算符

本教程将一个接一个介绍算术,关系比较和逻辑运算符。字符串运算符将在下章讨论。

算术运算符

下表列出了所有PL/SQL支持的算术运算符。假设变量A=10和可变B=5,则:

运算符 描述 示例
+ 相加两个操作数 A + B = 15
- 第一个操作数减去第二个操作数 A - B = 5
* 两个操作数相乘 A * B = 50
/ 两个操作数相除 A / B = 2
** 乘方运算 A ** B = 100000

示例:

  1. BEGIN
  2. dbms_output.put_line( 10 + 5);
  3. dbms_output.put_line( 10 - 5);
  4. dbms_output.put_line( 10 * 5);
  5. dbms_output.put_line( 10 / 5);
  6. dbms_output.put_line( 10 ** 5);
  7. END;
  8. /

当上述代码在SQL提示符执行时,它产生了以下结果:

  1. 15
  2. 5
  3. 50
  4. 2
  5. 100000
  6.  
  7. PL/SQL procedure successfully completed.

关系运算符

关系运算符比较两个表达式或值,并返回一个布尔结果。下表列出了所有PL/SQL支持的关系运算符。假设变量A=10,变量B=20,则:

运算符 描述 示例
= 检查两个操作数的值是否相等,如果是的话那么条件为真。 (A = B) 结果为 false.
!=
<>
~=
检查两个操作数的值是否相等,如果值不相等,则条件变为真。 (A != B) 结果为 true.
> 检查左边的操作数的值是否大于右操作数的值,如果是的话那么条件为真。 (A > B) 结果为 false.
< 检查左边的操作数的值是否小于右操作数的值,如果是的话那么条件为真。 (A < B) 结果为 true.
>= 检查左边的操作数的值是否大于或等于右操作数的值,如果是的话那么条件为真。 (A >= B)  结果为 false.
<= 检查左边的操作数的值是否小于或等于右操作数的值,如果是的话那么条件为真。 (A <= B) 结果为 true.

示例:

  1. DECLARE
  2. a number (2) := 21;
  3. b number (2) := 10;
  4. BEGIN
  5. IF (a = b) then
  6. dbms_output.put_line('Line 1 - a is equal to b');
  7. ELSE
  8. dbms_output.put_line('Line 1 - a is not equal to b');
  9. END IF;
  10.  
  11. IF (a < b) then
  12. dbms_output.put_line('Line 2 - a is less than b');
  13. ELSE
  14. dbms_output.put_line('Line 2 - a is not less than b');
  15. END IF;
  16.  
  17. IF ( a > b ) THEN
  18. dbms_output.put_line('Line 3 - a is greater than b');
  19. ELSE
  20. dbms_output.put_line('Line 3 - a is not greater than b');
  21. END IF;
  22.  
  23. -- Lets change value of a and b
  24. a := 5;
  25. b := 20;
  26. IF ( a <= b ) THEN
  27. dbms_output.put_line('Line 4 - a is either equal or less than b');
  28. END IF;
  29.  
  30. IF ( b >= a ) THEN
  31. dbms_output.put_line('Line 5 - b is either equal or greater than a');
  32. END IF;
  33.  
  34. IF ( a <> b ) THEN
  35. dbms_output.put_line('Line 6 - a is not equal to b');
  36. ELSE
  37. dbms_output.put_line('Line 6 - a is equal to b');
  38. END IF;
  39.  
  40. END;
  41. /

当上述代码在SQL提示符执行时,它产生了以下结果:

  1. Line 1 - a is not equal to b
  2. Line 2 - a is not less than b
  3. Line 3 - a is greater than b
  4. Line 4 - a is either equal or less than b
  5. Line 5 - b is either equal or greater than a
  6. Line 6 - a is not equal to b
  7.  
  8. PL/SQL procedure successfully completed

比较运算符

比较运算符用于一个表达比较到另一个。结果总是 TRUE,FALSE或NULL。

运算符 描述 示例
LIKE LIKE操作一个字符,字符串或CLOB值进行比较匹配模式则返回TRUE,如果不匹配模式则FALSE 如果 'Zara Ali' like 'Z% A_i' 返回一个布尔值true, 然而, 'Nuha Ali' like 'Z% A_i' 返回布尔值 false
BETWEEN BETWEEN 运算符测试一个值是否位于规定的范围内. x BETWEEN a AND b 意思就是 x >= a and x <= b. 如果 x = 10 那么  x between 5 and 20 返回 true, x between 5 and 10 返回 true, 但是 x between 11 and 20 返回 false
IN IN运算符的测试设置成员. x IN (set) 意味着x等于集合中的某一个成员 如果  x = 'm' then, x in ('a', 'b', 'c') 返回布尔值false,但x在('m', 'n', 'o') 返回布尔值 true.
IS NULL IS NULL运算符返回布尔值true,如果它的操作数是NULL或FALSE(如果它不为NULL)。包括NULL值的比较总能取得NULL 如果  x = 'm', 那么 'x is null' 返回布尔值false

LIKE 运算符:

这个程序测试LIKE运算符,将学习如何在PL/ SQL程序使用,但这里用一个程序来显示LIKE运算符的功能:

  1. DECLARE
  2. PROCEDURE compare (value varchar2, pattern varchar2 ) is
  3. BEGIN
  4. IF value LIKE pattern THEN
  5. dbms_output.put_line ('True');
  6. ELSE
  7. dbms_output.put_line ('False');
  8. END IF;
  9. END;
  10.  
  11. BEGIN
  12. compare('Zara Ali', 'Z%A_i');
  13. compare('Nuha Ali', 'Z%A_i');
  14. END;
  15. /

当上述代码在SQL提示符执行时,它产生了以下结果:

  1. True
  2. False
  3.  
  4. PL/SQL procedure successfully completed.

BETWEEN运算符:

下面的程序显示了运算符BETWEEN的用法:

  1. DECLARE
  2. x number(2) := 10;
  3. BEGIN
  4. IF (x between 5 and 20) THEN
  5. dbms_output.put_line('True');
  6. ELSE
  7. dbms_output.put_line('False');
  8. END IF;
  9.  
  10. IF (x BETWEEN 5 AND 10) THEN
  11. dbms_output.put_line('True');
  12. ELSE
  13. dbms_output.put_line('False');
  14. END IF;
  15.  
  16. IF (x BETWEEN 11 AND 20) THEN
  17. dbms_output.put_line('True');
  18. ELSE
  19. dbms_output.put_line('False');
  20. END IF;
  21. END;
  22. /

当上述代码在SQL提示符执行时,它产生了以下结果:

  1. True
  2. True
  3. False
  4.  
  5. PL/SQL procedure successfully completed.

IN和IS NULL运算符:

下面的程序显示IN和IS NULL运算符的用法:

  1. DECLARE
  2. letter varchar2(1) := 'm';
  3. BEGIN
  4. IF (letter in ('a', 'b', 'c')) THEN
  5. dbms_output.put_line('True');
  6. ELSE
  7. dbms_output.put_line('False');
  8. END IF;
  9.  
  10. IF (letter in ('m', 'n', 'o')) THEN
  11. dbms_output.put_line('True');
  12. ELSE
  13. dbms_output.put_line('False');
  14. END IF;
  15.  
  16. IF (letter is null) THEN
  17. dbms_output.put_line('True');
  18. ELSE
  19. dbms_output.put_line('False');
  20. END IF;
  21. END;
  22. /

当上述代码在SQL提示符执行时,它产生了以下结果:

  1. False
  2. True
  3. False
  4.  
  5. PL/SQL procedure successfully completed.

逻辑运算符

下表显示了PL/SQL支持的逻辑运算符。所有这些操作符布尔运算,并产生布尔结果。假设变量A=true,变量B=false,那么:

运算符 描述 示例
and 称为逻辑AND运算。如果两个操作数为true,则条件为true (A and B) 结果为 false.
or 所谓的逻辑或操作。如果任何两个操作数为true,则条件变为true (A or B) 结果为 true.
not 所谓逻辑非运算符。用于反向操作数的逻辑状态。如果条件为true,那么逻辑非运算符将使它为false not (A and B) 结果为 true.

运算符:

  1. DECLARE
  2. a boolean := true;
  3. b boolean := false;
  4. BEGIN
  5. IF (a AND b) THEN
  6. dbms_output.put_line('Line 1 - Condition is true');
  7. END IF;
  8. IF (a OR b) THEN
  9. dbms_output.put_line('Line 2 - Condition is true');
  10. END IF;
  11. IF (NOT a) THEN
  12. dbms_output.put_line('Line 3 - a is not true');
  13. ELSE
  14. dbms_output.put_line('Line 3 - a is true');
  15. END IF;
  16. IF (NOT b) THEN
  17. dbms_output.put_line('Line 4 - b is not true');
  18. ELSE
  19. dbms_output.put_line('Line 4 - b is true');
  20. END IF;
  21. END;
  22. /

当上述代码在SQL提示符执行时,它产生了以下结果:

  1. Line 2 - Condition is true
  2. Line 3 - a is true
  3. Line 4 - b is not true
  4.  
  5. PL/SQL procedure successfully completed.

PL/SQL运算符优先级

运算符优先级确定表达式分组。这会影响一个表达式是如何进行计算。某些运算符的优先级高于其他运算符; 例如,乘法运算符的优先级比加法运算高:

例如 x =7 + 3* 2; 这里,x被赋值13,而不是20,因为运算符*具有优先级高于+,所以它首先被乘以3 * 2,然后再加上7。

这里,具有最高优先级的操作出现在表的顶部,那些具有最低出现在底部。在表达式,更高的优先级运算符将首先计算。

运算符 操作符
** 指数运算
+, - 加法,取反
*, / 乘法,除法
+, -, || 加,减,并置
=, <, >, <=, >=, <>, !=, ~=, ^=, 
IS NULL, LIKE, BETWEEN, IN
比较
NOT 逻辑否定
AND 关联
OR 包含

示例:

试试下面的例子来理解运算符优先级在PL/ SQL中的使用:

  1. DECLARE
  2. a number(2) := 20;
  3. b number(2) := 10;
  4. c number(2) := 15;
  5. d number(2) := 5;
  6. e number(2) ;
  7. BEGIN
  8. e := (a + b) * c / d; -- ( 30 * 15 ) / 5
  9. dbms_output.put_line('Value of (a + b) * c / d is : '|| e );
  10.  
  11. e := ((a + b) * c) / d; -- (30 * 15 ) / 5
  12. dbms_output.put_line('Value of ((a + b) * c) / d is : ' || e );
  13.  
  14. e := (a + b) * (c / d); -- (30) * (15/5)
  15. dbms_output.put_line('Value of (a + b) * (c / d) is : '|| e );
  16.  
  17. e := a + (b * c) / d; -- 20 + (150/5)
  18. dbms_output.put_line('Value of a + (b * c) / d is : ' || e );
  19. END;
  20. /

当上述代码在SQL提示符执行时,它产生了以下结果:

  1. Value of (a + b) * c / d is : 90
  2. Value of ((a + b) * c) / d is : 90
  3. Value of (a + b) * (c / d) is : 90
  4. Value of a + (b * c) / d is : 50
  5.  
  6. PL/SQL procedure successfully completed.

SQL记录-PLSQL运算符的更多相关文章

  1. SQL记录-PLSQL记录

    PL/SQL记录   PL/SQL记录就是可以容纳不同类型的数据项的数据结构.记录由不同字段,类似于数据库表的行. 例如,要保留跟踪图书馆中的书籍.可能要跟踪有关每本书下面的属性类似:标题,作者,主题 ...

  2. SQL记录-PLSQL基本语法与数据类型

    PL/SQL基本语法 PL/SQL是一种块结构的语言,这意味着PL/SQL程序被划分和编写代码的逻辑块.每块由三个子部分组成: S.N. 段和说明 1 声明 此部分开头使用关键字DECLARE.它是一 ...

  3. SQL记录-PLSQL游标

    PL/SQL游标 Oracle会创建一个存储区域,被称为上下文区域,用于处理SQL语句,其中包含需要处理的语句,例如所有的信息,行数处理,等等. 游标是指向这一上下文的区域. PL/SQL通过控制光标 ...

  4. SQL记录-PLSQL字符串

    PL/SQL字符串 PL/SQL字符串实际上是一个可选的尺寸规格字符序列.字符可以是数字,字母,空白,特殊字符或全部的组合. PL/SQL提供了三种类型的字符串: 固定长度字符串:在这样的字符串,程序 ...

  5. SQL记录-PLSQL条件控制

    PL/SQL条件控制   决策结构需要程序员指定一个或多个条件要计算,或由程序进行测试,如果条件被确定为真那么一条或多条语句被执行,如果要被执行的其它语句条件被确定为假,则选其它执行块. 以下是从在大 ...

  6. SQL记录-PLSQL变量与常量文字

    PL/SQL变量   变量是只不过是一个给定的存储区域,程序可以操纵的名称.PL/SQL每个变量具有一个特定的数据类型,它决定了大小和变量的存储器的值,可以说存储器和设置操作可以施加到可变内被存储的范 ...

  7. SQL记录-PLSQL包

    PL/SQL包 PL/SQL包是组逻辑相关的PL/SQL类型,变量和子程序模式对象. 程序包将有两个强制性的部分: 包装规范定义 包体或定义 包装规范定义 规范是接口到包.它只是声明的类型,变量,常量 ...

  8. SQL记录-PLSQL触发器

    PL/SQL触发器 触发器是存储程序,它会自动执行或发射当一些事件发生.触发器,事实上,写入响应于以下任一事件将被执行: 数据库操作(DML)语句(DELETE,INSERT,UPDATE或) 数据库 ...

  9. SQL记录-PLSQL函数

    PL/SQL函数 PL/SQL函数与过程相同,不同之处在于函数有一个返回值.因此,前面的章节中的所有讨论都适用于函数. 创建函数 建立一个独立函数可以使用CREATE FUNCTION语句创建.CRE ...

随机推荐

  1. pycharm如何全局进行查找一个关键词

    PyCharm的Find in Path功能提供了全局查找功能,快捷键为Ctrl + Shift + F.Find则是在当前文件查找,快捷键为Ctrl + F.这两个个功能非常实用. Find in ...

  2. docker之镜像管理命令

    一.docker image 镜像管理命令 指令 描述ls 列出本机镜像build 构建镜像来自Dockerfilehistory 查看镜像历史inspect 显示一个或多个镜像详细信息pull 从镜 ...

  3. 萌新程序媛的首个作品,基于NoSQL的内容管理及低码开发平台

    尽管入行有一段时间了,但之前还从来没想过要开发一款完整的软件产品.这个我跟朋友开发的第一款软件,希望大家帮我们多宣传推广.首个版本肯定有很多的不足,大家也给我们多提意见,还有很多规划中的功能要在之后的 ...

  4. 利用HOG+SVM实现行人检测

    利用HOG+SVM实现行人检测 很久以前做的行人检测,现在稍加温习,上传记录一下. 首先解析视频,提取视频的每一帧形成图片存到磁盘.代码如下 import os import cv2 videos_s ...

  5. [环境配置]Ubuntu 16.04 源码编译安装OpenCV-3.2.0+OpenCV_contrib-3.2.0及产生的问题

    1.OpenCV-3.2.0+OpenCV_contrib-3.2.0编译安装过程 1)下载官方要求的依赖包 GCC 4.4.x or later CMake 2.6 or higher Git GT ...

  6. Unity3d-通过简单示例来理解Time.deltaTime

    转载文章: Unity3d-通过简单示例来理解Time.deltaTime 2018年04月21日 18:04:14 Black_Window 阅读数:926 标签: UnityTime 更多 个人分 ...

  7. DVWA渗透测试系列 一 (DVWA环境配置)

    DVWA介绍: DVWA是一个渗透测试靶机系统. DVWA具有十个模块:分别是 Brute Force(暴力破解).Command Injection(命令行注入).CSRF(跨站请求伪造).File ...

  8. Alpha阶段个人贡献分及转会人员确定

    请各个团队协商确定个人贡献分,评分根据之前个团队确定的规则进行.每个团队的个人贡献分总数为50*N,N为团队的人数. 个人贡献分要求:必须是一个自然数,每个人分数互不相同,并且和为50*N. 请各个团 ...

  9. C语言版本:单链表的实现

    slist.h #ifndef __SLIST_H__ #define __SLIST_H__ #include<cstdio> #include<malloc.h> #inc ...

  10. [转帖] tmux 的使用说明

    之前曾经看过 tmux 的简介 但是一直不会用 这次 看了下 原来是这么处理 不过 用windows 多了 还是感觉鼠标 操作多一些 全键盘操作的习惯 还是没有养成. 原贴地址: https://ww ...