- PL/SQL 教程
- PL/SQL - 主页
- PL/SQL - 概述
- PL/SQL - 环境
- PL/SQL - 基本语法
- PL/SQL - 数据类型
- PL/SQL - 变量
- PL/SQL - 常量和文字
- PL/SQL - 运算符
- PL/SQL - 条件
- PL/SQL - 循环
- PL/SQL - 字符串
- PL/SQL - 数组
- PL/SQL - 过程
- PL/SQL - 函数
- PL/SQL - 游标
- PL/SQL - 记录
- PL/SQL - 异常
- PL/SQL - 触发器
- PL/SQL - 包
- PL/SQL - 集合
- PL/SQL - 事务
- PL/SQL - 日期和时间
- PL/SQL - DBMS 输出
- PL/SQL - 面向对象
- PL/SQL 有用资源
- PL/SQL - 问题与解答
- PL/SQL - 快速指南
- PL/SQL - 有用的资源
- PL/SQL - 讨论
PL/SQL - 运算符
在本章中,我们将讨论 PL/SQL 中的运算符。运算符是告诉编译器执行特定数学或逻辑操作的符号。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 |
关系运算符
关系运算符比较两个表达式或值并返回布尔结果。下表显示了 PL/SQL 支持的所有关系运算符。假设变量 A为 10,变量 B为 20,则 -
操作员 | 描述 | 例子 |
---|---|---|
= | 检查两个操作数的值是否相等,如果相等则条件为真。 | (A = B) 不正确。 |
!= <> 〜= |
检查两个操作数的值是否相等,如果值不相等则条件成立。 | (A != B) 为真。 |
> | 检查左操作数的值是否大于右操作数的值,如果是,则条件为真。 | (A > B) 不正确。 |
< | 检查左操作数的值是否小于右操作数的值,如果是,则条件为真。 | (A < B) 为真。 |
>= | 检查左操作数的值是否大于或等于右操作数的值,如果是,则条件为真。 | (A >= B) 不正确。 |
<= | 检查左操作数的值是否小于或等于右操作数的值,如果是,则条件为真。 | (A <= B) 为真 |
比较运算符
比较运算符用于将一个表达式与另一个表达式进行比较。结果始终为TRUE、FALSE或NULL。
操作员 | 描述 | 例子 |
---|---|---|
喜欢 | LIKE 运算符将字符、字符串或 CLOB 值与模式进行比较,如果该值与模式匹配则返回 TRUE,如果不匹配则返回 FALSE。 | 如果“Zara Ali”如“Z% A_i”返回布尔值 true,而“Nuha Ali”如“Z% A_i”返回布尔值 false。 |
之间 | BETWEEN 运算符测试某个值是否位于指定范围内。x BETWEEN a AND b 表示 x >= a 且 x <= b。 | 如果 x = 10,则 5 到 20 之间的 x 返回 true,5 到 10 之间的 x 返回 true,11 到 20 之间的 x 返回 false。 |
在 | IN 运算符测试集成员资格。x IN(集合)意味着x等于集合的任何成员。 | 如果 x = 'm',则 x in ('a', 'b', 'c') 返回布尔值 false,但 x in ('m', 'n', 'o') 返回布尔值 true。 |
一片空白 | 如果 IS NULL 运算符的操作数为 NULL,则返回 BOOLEAN 值 TRUE;如果操作数不为 NULL,则返回 FALSE。涉及 NULL 值的比较始终会产生 NULL。 | 如果 x = 'm',则 'x is null' 返回布尔值 false。 |
逻辑运算符
下表显示了 PL/SQL 支持的逻辑运算符。所有这些运算符都处理布尔操作数并产生布尔结果。假设变量 A为 true,变量 B为 false,则 -
操作员 | 描述 | 例子 |
---|---|---|
和 | 称为逻辑与运算符。如果两个操作数都为 true,则条件为 true。 | (A 和 B)是错误的。 |
或者 | 称为逻辑或运算符。如果两个操作数中的任何一个为真,则条件为真。 | (A 或 B)为真。 |
不是 | 称为逻辑非运算符。用于反转其操作数的逻辑状态。如果条件为真,则逻辑 NOT 运算符会将其设为假。 | 不是(A 和 B)为真。 |
PL/SQL 运算符优先级
运算符优先级决定表达式中术语的分组。这会影响表达式的计算方式。某些运算符的优先级高于其他运算符;例如,乘法运算符的优先级高于加法运算符。
例如,x = 7 + 3 * 2;这里,x被分配为13 ,而不是 20 ,因为运算符 * 的优先级高于 + ,因此它首先与3*2相乘,然后添加到7。
在这里,优先级最高的运算符出现在表的顶部,优先级最低的运算符出现在底部。在表达式中,将首先计算优先级较高的运算符。
运算符的优先级如下:=、<、>、<=、>=、<>、!=、~=、^=、IS NULL、LIKE、BETWEEN、IN。
操作员 | 手术 |
---|---|
** | 求幂 |
+、- | 同一性、否定性 |
*, / | 乘法、除法 |
+、-、|| | 加法、减法、连接 |
比较 | |
不是 | 逻辑否定 |
和 | 连词 |
或者 | 包容性 |