目录
运算符是一个符号,它告诉编译器执行指定的数学或逻辑操作。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。
运算符 | 描述 |
LIKE | LIKE运算符将字符,字符串或CLOB值与模式进行比较,如果值与模式匹配,则返回TRUE,否则返回FALSE。 |
BETWEEN | BETWEEN运算符测试值是否在指定范围内。x BETWEEN a AND b表示x >= a且x <= b。 |
IN | IN运算符测试集成员数据。 x IN(set)表示x等于集合中的任何成员数据。 |
IS NULL | IS 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 | 逻辑或 |