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 |
示例:
BEGIN dbms_output.put_line( 10 + 5); dbms_output.put_line( 10 - 5); dbms_output.put_line( 10 * 5); dbms_output.put_line( 10 / 5); dbms_output.put_line( 10 ** 5); END; /
當上述代碼在SQL提示符執行時,它產生了以下結果:
15 5 50 2 100000 PL/SQL procedure successfully completed.
關系運算符
關系運算符比較兩個表達式或值,並返回一個布爾結果。下表列出了所有PL/SQL支持的關系運算符。假設變量A=10,變量B=20,則:
| 運算符 | 描述 | 示例 |
|---|---|---|
| = | 檢查兩個操作數的值是否相等,如果是的話那么條件為真。 | (A = B) 結果為 false. |
| != <> ~= |
檢查兩個操作數的值是否相等,如果值不相等,則條件變為真。 | (A != B) 結果為 true. |
| > | 檢查左邊的操作數的值是否大於右操作數的值,如果是的話那么條件為真。 | (A > B) 結果為 false. |
| < | 檢查左邊的操作數的值是否小於右操作數的值,如果是的話那么條件為真。 | (A < B) 結果為 true. |
| >= | 檢查左邊的操作數的值是否大於或等於右操作數的值,如果是的話那么條件為真。 | (A >= B) 結果為 false. |
| <= | 檢查左邊的操作數的值是否小於或等於右操作數的值,如果是的話那么條件為真。 | (A <= B) 結果為 true. |
示例:
DECLARE a number (2) := 21; b number (2) := 10; BEGIN IF (a = b) then dbms_output.put_line('Line 1 - a is equal to b'); ELSE dbms_output.put_line('Line 1 - a is not equal to b'); END IF; IF (a < b) then dbms_output.put_line('Line 2 - a is less than b'); ELSE dbms_output.put_line('Line 2 - a is not less than b'); END IF; IF ( a > b ) THEN dbms_output.put_line('Line 3 - a is greater than b'); ELSE dbms_output.put_line('Line 3 - a is not greater than b'); END IF; -- Lets change value of a and b a := 5; b := 20; IF ( a <= b ) THEN dbms_output.put_line('Line 4 - a is either equal or less than b'); END IF; IF ( b >= a ) THEN dbms_output.put_line('Line 5 - b is either equal or greater than a'); END IF; IF ( a <> b ) THEN dbms_output.put_line('Line 6 - a is not equal to b'); ELSE dbms_output.put_line('Line 6 - a is equal to b'); END IF; END; /
當上述代碼在SQL提示符執行時,它產生了以下結果:
Line 1 - a is not equal to b Line 2 - a is not less than b Line 3 - a is greater than b Line 4 - a is either equal or less than b Line 5 - b is either equal or greater than a Line 6 - a is not equal to b PL/SQL procedure successfully completed
比較運算符
比較運算符用於一個表達比較到另一個。結果總是 TRUE,FALSE或NULL。
| 運算符 | 描述 | 示例 |
|---|---|---|
| LIKE | LIKE操作一個字符,字符串或CLOB值進行比較匹配模式則返回TRUE,如果不匹配模式則FALSE | 如果 'Zara Ali' like 'Z% A_i' 返回一個布爾值true, 然而, 'Nuha Ali' like 'Z% A_i' 返回布爾值 false |
| BETWEEN | BETWEEN 運算符測試一個值是否位於規定的范圍內. 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 |
| IN | IN運算符的測試設置成員. x IN (set) 意味着x等於集合中的某一個成員 | 如果 x = 'm' then, x in ('a', 'b', 'c') 返回布爾值false,但x在('m', 'n', 'o') 返回布爾值 true. |
| IS NULL | IS NULL運算符返回布爾值true,如果它的操作數是NULL或FALSE(如果它不為NULL)。包括NULL值的比較總能取得NULL | 如果 x = 'm', 那么 'x is null' 返回布爾值false |
LIKE 運算符:
這個程序測試LIKE運算符,將學習如何在PL/ SQL程序使用,但這里用一個程序來顯示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; BEGIN compare('Zara Ali', 'Z%A_i'); compare('Nuha Ali', 'Z%A_i'); END; /
當上述代碼在SQL提示符執行時,它產生了以下結果:
True False PL/SQL procedure successfully completed.
BETWEEN運算符:
下面的程序顯示了運算符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; IF (x BETWEEN 5 AND 10) THEN dbms_output.put_line('True'); ELSE dbms_output.put_line('False'); END IF; IF (x BETWEEN 11 AND 20) THEN dbms_output.put_line('True'); ELSE dbms_output.put_line('False'); END IF; END; /
當上述代碼在SQL提示符執行時,它產生了以下結果:
True True False PL/SQL procedure successfully completed.
IN和IS NULL運算符:
下面的程序顯示IN和IS NULL運算符的用法:
DECLARE 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 in ('m', 'n', 'o')) 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; /
當上述代碼在SQL提示符執行時,它產生了以下結果:
False True False PL/SQL procedure successfully completed.
邏輯運算符
下表顯示了PL/SQL支持的邏輯運算符。所有這些操作符布爾運算,並產生布爾結果。假設變量A=true,變量B=false,那么:
| 運算符 | 描述 | 示例 |
|---|---|---|
| and | 稱為邏輯AND運算。如果兩個操作數為true,則條件為true | (A and B) 結果為 false. |
| or | 所謂的邏輯或操作。如果任何兩個操作數為true,則條件變為true | (A or B) 結果為 true. |
| not | 所謂邏輯非運算符。用於反向操作數的邏輯狀態。如果條件為true,那么邏輯非運算符將使它為false | not (A and B) 結果為 true. |
運算符:
DECLARE a boolean := true; b boolean := false; BEGIN IF (a AND b) THEN dbms_output.put_line('Line 1 - Condition is true'); END IF; IF (a OR b) THEN dbms_output.put_line('Line 2 - Condition is true'); END IF; IF (NOT a) THEN dbms_output.put_line('Line 3 - a is not true'); ELSE dbms_output.put_line('Line 3 - a is true'); END IF; IF (NOT b) THEN dbms_output.put_line('Line 4 - b is not true'); ELSE dbms_output.put_line('Line 4 - b is true'); END IF; END; /
當上述代碼在SQL提示符執行時,它產生了以下結果:
Line 2 - Condition is true Line 3 - a is true Line 4 - b is not true PL/SQL procedure successfully completed.
PL/SQL運算符優先級
運算符優先級確定表達式分組。這會影響一個表達式是如何進行計算。某些運算符的優先級高於其他運算符; 例如,乘法運算符的優先級比加法運算高:
例如 x =7 + 3* 2; 這里,x被賦值13,而不是20,因為運算符*具有優先級高於+,所以它首先被乘以3 * 2,然后再加上7。
這里,具有最高優先級的操作出現在表的頂部,那些具有最低出現在底部。在表達式,更高的優先級運算符將首先計算。
| 運算符 | 操作符 |
|---|---|
| ** | 指數運算 |
| +, - | 加法,取反 |
| *, / | 乘法,除法 |
| +, -, || | 加,減,並置 |
| =, <, >, <=, >=, <>, !=, ~=, ^=, IS NULL, LIKE, BETWEEN, IN |
比較 |
| NOT | 邏輯否定 |
| AND | 關聯 |
| OR | 包含 |
示例:
試試下面的例子來理解運算符優先級在PL/ SQL中的使用:
DECLARE
a number(2) := 20;
b number(2) := 10;
c number(2) := 15;
d number(2) := 5;
e number(2) ;
BEGIN
e := (a + b) * c / d; -- ( 30 * 15 ) / 5
dbms_output.put_line('Value of (a + b) * c / d is : '|| e );
e := ((a + b) * c) / d; -- (30 * 15 ) / 5
dbms_output.put_line('Value of ((a + b) * c) / d is : ' || e );
e := (a + b) * (c / d); -- (30) * (15/5)
dbms_output.put_line('Value of (a + b) * (c / d) is : '|| e );
e := a + (b * c) / d; -- 20 + (150/5)
dbms_output.put_line('Value of a + (b * c) / d is : ' || e );
END;
/
當上述代碼在SQL提示符執行時,它產生了以下結果:
Value of (a + b) * c / d is : 90 Value of ((a + b) * c) / d is : 90 Value of (a + b) * (c / d) is : 90 Value of a + (b * c) / d is : 50 PL/SQL procedure successfully completed.
