運算符號是一個符號,告訴編譯器執行特定的數學或邏輯操作。 PL/SQL語言有豐富的內置運算符號,運算符號提供的以下幾種類型:
· 數學運算符號
· 關係運算符號
· 比較運算符號
· 邏輯運算符號
· 字串運算符號
數學運算符號
下表列出了所有PL/SQL支持的算術運算符號。假設變量A=10和可變B=5,則:
請查閱5-1數學運算符號範例
運算符號
|
描述
|
範例
|
+
|
相加兩個數值
|
A + B = 15
|
-
|
第一個數值減去第二個數值
|
A - B = 5
|
*
|
兩個數值相乘
|
A * B = 50
|
/
|
兩個數值相除
|
A / B = 2
|
**
|
次方運算
|
A ** B = 100000
|
關係運算符號
關係運算符號比較兩個表達式或值,並回傳一個布林結果。下表列出了所有PL/SQL支持的關係運算符號。假設變量A=10,變量B=20,則:
請查閱5-2關係運算符號範例
運算符號
|
描述
|
範例
|
=
|
檢查兩邊的值是否相等,如果是的話那麼條件為真。
|
(A = B) 結果為 false.
|
!= <> ~=
|
檢查兩個數值的值是否相等,如果值不相等,則條件變為真。
|
(A != B) 結果為 true.
|
>
|
檢查左邊的數值的值是否大於右數值的值,如果是的話那麼條件為真。
|
(A > B) 結果為 false.
|
<
|
檢查左邊的數值的值是否小於右數值的值,如果是的話那麼條件為真。
|
(A < B) 結果為 true.
|
>=
|
檢查左邊的數值的值是否大於或等於右數值的值,如果是的話那麼條件為真。
|
(A >= B) 結果為 false.
|
<=
|
檢查左邊的數值的值是否小於或等於右數值的值,如果是的話那麼條件為真。
|
(A <= B) 結果為 true.
|
比較運算符號
比較運算符號用於一個表達比較到另一個。結果總是 TRUE,FALSE或NULL。
請查閱5-3比較運算符號範例
運算符號
|
描述
|
範例
|
LIKE
|
LIKE會確認字串得值,將字串值進行比較匹配模式則回傳TRUE,如果不匹配模式則FALSE
|
如果 'Tim Chang' like 'T% C_g' 回傳一個布林值true,當 'Gim Chen' like 'T% C_g' 回傳布林值 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
|
邏輯運算符號
運算符號
|
描述
|
範例
|
and
|
稱為邏輯AND運算。如果兩個數值為true,則條件為true
|
(A and B) 結果為 false.
|
or
|
所謂的邏輯或操作。如果任何兩個數值為true,則條件變為true
|
(A or B) 結果為 true.
|
not
|
所謂邏輯非運算符號。用於反向數值的邏輯狀態。如果條件為true,那麼邏輯非運算符號將使它為false
|
not (A and B) 結果為 true.
|
PL/SQL運算符號優先級
運算符號優先級確定表達式分組。這會影響一個表達式是如何進行計算。某些運算符號的優先級高於其他運算符號; 例如,乘法運算符號的優先級比加法運算高:
例如 x =7 + 3* 2; 這裡,x被賦值13,而不是20,因為運算符號*具有優先級高於+,所以它首先被乘以3 * 2,然後再加上7。
這裡,具有最高優先級的運算出現在表格的頂部,那些具有最低出現在底部。在表達式,更高的優先級運算符號將首先計算。
請查閱5-5運算符號優先級範例
運算符號
|
操作符號
|
**
|
指數運算
|
*, /
|
乘法,除法
|
+, -, ||
|
加,減,並置
|
=, <, >, <=, >=, <>, !=, ~=, ^=, IS NULL, LIKE, BETWEEN, IN
|
比較
|
NOT
|
邏輯否定
|
AND
|
關聯
|
OR
|
包含
|
沒有留言:
張貼留言