PL/SQL运算符

目录

连接运算符

算术运算符

关系运算符

比较运算符

逻辑运算符

运算符优先级


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

  • 连接运算符
  • 算术运算符
  • 关系运算符
  • 比较运算符
  • 逻辑运算符

连接运算符

        连接运算符(||)将一个字符串操作数附加到另一个。每个字符串可以是CHAR,VARCHAR2,CLOB。如果任一个字符串是CLOB,则结果是临时CLOB;否则,它是一个VARCHAR2值。

DECLARE
  x VARCHAR2(4) := 'Hi';
  y VARCHAR2(10) := ' Hey';
BEGIN
  DBMS_OUTPUT.PUT_LINE (x || y); -- 执行结果为:Hi Hey
END;
/

算术运算符

        下表显示了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) 为真
  • 比较两个CHAR值
DECLARE
  last_name1 CHAR(5)  := 'HELLO';          -- no trailing blanks
  last_name2 CHAR(10) := 'HELLO     ';     -- trailing blanks
BEGIN
 IF last_name1 = last_name2 THEN
   DBMS_OUTPUT.PUT_LINE (last_name1 || ' is equal to ' || last_name2);
 ELSE
   DBMS_OUTPUT.PUT_LINE (last_name2 || ' is not equal to ' || last_name1);
 END IF;
END;
/

-- 执行结果
HELLO is equal to HELLO
  • 比较两个VARCHAR2值
DECLARE
  last_name1 VARCHAR2(10) := 'HTML';
  last_name2 VARCHAR2(10) := 'HTML5';
BEGIN
  IF last_name1 > last_name2 THEN
    DBMS_OUTPUT.PUT_LINE (last_name1 || ' is greater than ' || last_name2);
  ELSE
    DBMS_OUTPUT.PUT_LINE (last_name2 || ' is greater than ' || last_name1 );
  END IF;
END;
/

-- 执行结果
HTML5 is greater than HTML
  • 比较CHAR值和VARCHAR2值
DECLARE
  last_name1 VARCHAR2(10) := 'HELLO';
  last_name2 CHAR(10)     := 'HELLO';  -- PL/SQL blank-pads value
BEGIN
  IF last_name1 = last_name2 THEN
    DBMS_OUTPUT.PUT_LINE (last_name1 || ' is equal to ' || last_name2);
  ELSE
    DBMS_OUTPUT.PUT_LINE (last_name2 || ' is not equal to ' || last_name1 );
  END IF;
END;
/

-- 执行结果
HELLO      is not equal to HELLO

比较运算符

        比较运算符用于将一个表达式与另一个表达式作比较。结果始终为TRUE,FALSE或NULL。

运算符描述
LIKELIKE运算符将字符,字符串或CLOB值与模式进行比较,如果值与模式匹配,则返回TRUE,否则返回FALSE。
BETWEENBETWEEN运算符测试值是否在指定范围内。x BETWEEN a AND b表示x >= a且x <= b。
ININ运算符测试集成员数据。 x IN(set)表示x等于集合中的任何成员数据。
IS NULLIS NULL运算符如果其操作数为NULL返回值为TRUE,如果不为NULL则返回FALSE。

LIKE运算符:

DECLARE 
    PROCEDURE compare (value  varchar2,  pattern varchar2 )
    IS
    BEGIN
       IF value LIKE pattern THEN
          dbms_output.put_line ('True');
       ELSE
          dbms_output.put_line ('False');
       END IF;
    END compare;
BEGIN
   compare('Zara Ali', 'Z%A_i'); -- True
   compare('Nuha Ali', 'Z%A_i'); -- False
END;
/

BETWEEN运算符:

DECLARE
   x number(2) := 10;
BEGIN
   IF (x between 5 and 20) THEN
      dbms_output.put_line('True');
   ELSE
      dbms_output.put_line('False');
   END IF;
END;
/

IN和IS NULL运算符:

ECLARE
   letter varchar2(1) := 'm';
BEGIN 
   IF (letter in ('a', 'b', 'c')) THEN
      dbms_output.put_line('True');
   ELSE
      dbms_output.put_line('False');
   END IF;

   IF (letter is null) THEN
      dbms_output.put_line('True');
   ELSE
      dbms_output.put_line('False');
   END IF;
END;
/

逻辑运算符

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

运算符描述示例
and逻辑与运算符。如果两个操作数都为真,则条件成立。(A and B) 为假
or逻辑或运算符。如果两个操作数中的任何一个为真,则条件成为真。(A or B)是真
not逻辑非运算符。用于反转其操作数的逻辑状态。如果条件为真,则逻辑NOT运算符将使其为false(not A)结果为FALSE

运算符优先级

        表达式中的操作按优先级顺序进行计算。具有相等优先级的运算符不以特定顺序应用。

我们可以使用括号来控制评估的顺序。下表显示了从最高到最低的运算符优先级。

运算符操作描述
**指数幂运算符
+, -标识符,负数
*, /乘法,除法
+, -, ||加法,减法,连接
=, <, >, <=, >=, <>, !=, ~=, ^=, IS NULL, LIKE, BETWEEN, IN比较
NOT逻辑否定
AND逻辑与
OR逻辑或
  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PL /SQL是一种高级数据库程序设计语言,该语言专门用于在各种环境下对ORACLE数据库进行访问。由于该语言集成于数据库服务器中,所以PL/SQL代码可以对数据进行快速高效的处理。除此之外,可以在ORACLE数据库的某些客户端工具中,使用PL/SQL语言也是该语言的一个特点。本章的主要内容是讨论引入PL/SQL语言的必要性和该语言的主要特点,以及了解PL/SQL语言的重要性和数据库版本问题。还要介绍一些贯穿全书的更详细的高级概念,并在本章的最后就我们在本书案例中使用的数据库表的若干约定做一说明。 本章主要重点: PL/SQL概述 PL/SQL块结构 PL/SQL流程 运算符和表达式 游标 异常处理 数据库存储过程和函数 包 触发器 §1.2 SQLPL/SQL §1.2.1 什么是PL/SQL? PL/SQL是 Procedure Language & Structured Query Language 的缩写。ORACLE的SQL是支持ANSI(American national Standards Institute)和ISO92 (International Standards Organization)标准的产品。PL/SQL是对SQL语言存储过程语言的扩展。从ORACLE6以后,ORACLE的RDBMS附带了PL/SQL。它现在已经成为一种过程处理语言,简称PL/SQL。目前的PL/SQL包括两部分,一部分是数据库引擎部分;另一部分是可嵌入到许多产品(如C语言,JAVA语言等)工具中的独立引擎。可以将这两部分称为:数据库PL/SQL和工具PL/SQL。两者的编程非常相似。都具有编程结构、语法和逻辑机制。工具PL/SQL另外还增加了用于支持工具(如ORACLE Forms)的句法,如:在窗体上设置按钮等。本章主要介绍数据库PL/SQL内容。 §1.2.1 PL/SQL的好处 §1.2.1.1 有利于客户/服务器环境应用的运行 对于客户/服务器环境来说,真正的瓶颈是网络上。无论网络多快,只要客户端与服务器进行大量的数据交换。应用运行的效率自然就回受到影响。如果使用PL/SQL进行编程,将这种具有大量数据处理的应用放在服务器端来执行。自然就省去了数据在网上的传输时

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值