PL/SQL 運(yùn)算符

2021-08-30 14:55 更新

在本章中,我們將學(xué)習(xí)在PL/SQL中如何使用運(yùn)算符。 運(yùn)算符是一個(gè)符號(hào),它告訴編譯器執(zhí)行指定的數(shù)學(xué)或邏輯操作。PL/SQL語(yǔ)言中有豐富的內(nèi)置運(yùn)算符,提供有以下類(lèi)型的運(yùn)算符 -

  • 算術(shù)運(yùn)算符
  • 關(guān)系運(yùn)算符
  • 比較運(yùn)算符
  • 邏輯運(yùn)算符
  • 字符串運(yùn)算符

在這里,我們將逐個(gè)地來(lái)了解算術(shù),關(guān)系,比較和邏輯運(yùn)算符。字符串運(yùn)算符將在后面的章節(jié)(PL/SQL字符串)中學(xué)習(xí)。

算術(shù)運(yùn)算符

下表顯示了PL/SQL支持的所有算術(shù)運(yùn)算符。假設(shè)變量A的值為10,變量B的值為5,那么 -

算術(shù)運(yùn)算符示例

運(yùn)算符 描述 示例
+ 兩個(gè)操作數(shù)相加 A + B = 15
- 從第一個(gè)減去第二個(gè)操作數(shù) A - B = 5
* 將兩個(gè)操作數(shù)相乘 A * B = 50
/ 從第一個(gè)除以第二個(gè)操作數(shù) A / B = 2
** 指數(shù)運(yùn)算符,提出一個(gè)操作數(shù)到其他的冪值 A ** B = 100000

關(guān)系運(yùn)算符

關(guān)系運(yùn)算符比較兩個(gè)表達(dá)式或值,并返回一個(gè)布爾結(jié)果。 下表顯示了PL/SQL支持的所有關(guān)系運(yùn)算符。假設(shè)變量A=10,變量B=20,則 -

關(guān)系運(yùn)算符示例

運(yùn)算符 描述 示例
= 檢查兩個(gè)操作數(shù)的值是否相等,如果是,則條件成立。 (A = B)為假
!=,<>~= 檢查兩個(gè)操作數(shù)的值是否相等,如果兩個(gè)值不相等則條件成為真。 (A != B)為真
> 檢查左操作數(shù)的值是否大于右操作數(shù)的值,如果是,則條件成為真。 (A > B) 為假
< 檢查左操作數(shù)的值是否小于右操作數(shù)的值,如果是,則條件成為真。 (A < B) 條件為真。
>= 檢查左操作數(shù)的值是否大于或等于右操作數(shù)的值,如果是,則條件成為真。 (A >= B) 為假
<= 檢查左操作數(shù)的值是否小于或等于右操作數(shù)的值,如果是,則條件成為真。 (A <= B) 為真

比較運(yùn)算符

比較運(yùn)算符用于將一個(gè)表達(dá)式與另一個(gè)表達(dá)式作比較。結(jié)果始終為T(mén)RUE,F(xiàn)ALSE或NULL。

比較運(yùn)算符示例

運(yùn)算符 描述 示例
LIKE LIKE運(yùn)算符將字符,字符串或CLOB值與模式進(jìn)行比較,如果值與模式匹配,則返回TRUE,否則返回FALSE。 如果'Zara Ali' LIKE 'Z%A_i'返回一個(gè)布爾值true,而'Nuha Ali' LIKE'Z%A_i'返回一個(gè)布爾值。
BETWEEN BETWEEN運(yùn)算符測(cè)試值是否在指定范圍內(nèi)。x BETWEEN a AND b表示x >= ax <= b。 如果x = 10,那么在520之間則x返回true,x510之間則x返回true,但是x1120之間返回false。
IN IN運(yùn)算符測(cè)試集成員數(shù)據(jù)。 x IN(set)表示x等于集合中的任何成員數(shù)據(jù)。 如果x ='m',則在('a','b','c')x返回false,而在('m','n','o')x返回true。
IS NULL IS NULL運(yùn)算符如果其操作數(shù)為NULL返回值為TRUE,如果不為NULL則返回FALSE。 涉及NULL值的比較總是產(chǎn)生NULL 如果x ='m',則is null'返回false

邏輯運(yùn)算符

下表顯示了PL/SQL支持的邏輯運(yùn)算符。所有這些運(yùn)算符都使用布爾運(yùn)算符并產(chǎn)生布爾運(yùn)算結(jié)果。假設(shè)變量A=TRUE,變量B=FALSE,那么 -

邏輯運(yùn)算符示例

運(yùn)算符 描述 示例
and 邏輯與運(yùn)算符。如果兩個(gè)操作數(shù)都為真,則條件成立。 (A and B) 為假
or 邏輯或運(yùn)算符。如果兩個(gè)操作數(shù)中的任何一個(gè)為真,則條件成為真。 (A or B)是真
not 邏輯非運(yùn)算符。用于反轉(zhuǎn)其操作數(shù)的邏輯狀態(tài)。如果條件為真,則邏輯NOT運(yùn)算符將使其為false (not A)結(jié)果為FALSE

PL/SQL運(yùn)算符優(yōu)先級(jí)

運(yùn)算符優(yōu)先級(jí)決定表達(dá)式中術(shù)語(yǔ)的分組。這會(huì)影響表達(dá)式的評(píng)估求值順序。某些運(yùn)算符的優(yōu)先級(jí)高于其他運(yùn)算符; 例如,乘法運(yùn)算符的優(yōu)先級(jí)高于加法運(yùn)算符。

例如,x = 7 + 3 * 2; 這里,求值結(jié)果x的值為13,而不是20,因?yàn)檫\(yùn)算符 *的優(yōu)先級(jí)高于+,所以它首先被乘以3 * 2,然后再加上7。

在這里,優(yōu)先級(jí)最高的運(yùn)算符出現(xiàn)在表的頂部,最底層的運(yùn)算符出現(xiàn)在底部。在一個(gè)表達(dá)式中,將首先評(píng)估求值較高優(yōu)先級(jí)的運(yùn)算符。

運(yùn)算符的優(yōu)先級(jí)如下:=,<,>,<=,>=,<>,!=,?=,^=,IS NULL,LIKE,BETWEEN,IN。

運(yùn)算符優(yōu)先級(jí)示例

運(yùn)算符 操作描述
** 指數(shù)冪運(yùn)算符
+, - 標(biāo)識(shí)符,負(fù)數(shù)
*, / 乘法,除法
+, -, ΙΙ 加,減,連接
NOT 邏輯否定
AND 連詞(邏輯與)
OR 包含(邏輯或)

 



以上內(nèi)容是否對(duì)您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)