返回介绍

PL/SQL 运算符 - PL/SQL 教程

发布于 2025-02-22 13:46:46 字数 4190 浏览 0 评论 0 收藏 0

运算符是一个符号,告诉编译器执行特定的数学或逻辑操作。 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) 结果为 false.
!= <> ~=检查两个操作数的值是否相等,如果值不相等,则条件变为真。(A != B) 结果为 true.
>检查左边的操作数的值是否大于右操作数的值,如果是的话那么条件为真。(A > B) 结果为 false.
<检查左边的操作数的值是否小于右操作数的值,如果是的话那么条件为真。(A < B) 结果为 true.
>=检查左边的操作数的值是否大于或等于右操作数的值,如果是的话那么条件为真。(A >= B) 结果为 false.
<=检查左边的操作数的值是否小于或等于右操作数的值,如果是的话那么条件为真。(A <= B) 结果为 true.

比较运算符

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

显示比较运算符示例

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

逻辑运算符

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

显示逻辑运算符示例

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

PL/SQL 运算符优先级

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

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

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

查看运算符优先级实例

运算符操作符
**指数运算
+, -加法,取反
*, /乘法,除法
+, -, ||加,减,并置
=, <, >, <=, >=, <>, !=, ~=, ^=,

IS NULL, LIKE, BETWEEN, IN | 比较 | | NOT | 逻辑否定 | | AND | 关联 | | OR | 包含 |

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文