SQL記錄-PLSQL運算符

PL/SQL運算符

運算符是一個符號,告訴編譯器執行特定的數學或邏輯操做。 PL/SQL語言有豐富的內置運算符,運算符提供的如下幾種類型:sql

  • 算術運算符less

  • 關係運算符學習

  • 比較運算符測試

  • 邏輯運算符spa

  • 字符串運算符教程

本教程將一個接一個介紹算術,關係比較和邏輯運算符。字符串運算符將在下章討論。字符串

算術運算符

下表列出了全部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提示符執行時,它產生了如下結果:it

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.
相關文章
相關標籤/搜索