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、FALSENULL

显示示例

操作员 描述 例子
喜欢 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。

显示示例

操作员 手术
** 求幂
+、- 同一性、否定性
*, / 乘法、除法
+、-、|| 加法、减法、连接
比较
不是 逻辑否定
连词
或者 包容性