比較運算符用於將一個運算式與另一個運算式作比較。結果始終為TRUE,FALSE或NULL。
| 運算符 | 描述 | 示例 |
|---|---|---|
LIKE |
LIKE運算符將字元,字串或CLOB值與模式進行比較,如果值與模式匹配,則返回TRUE,否則返回FALSE。 |
如果'Zara Ali' LIKE 'Z%A_i'返回一個布爾值true,而'Nuha Ali' LIKE'Z%A_i'返回一個布爾值。 |
BETWEEN |
BETWEEN運算符測試值是否在指定範圍內。x BETWEEN a AND b表示x >= a和x <= b。 |
如果x = 10,那麼在5到20之間則x返回true,x在5和10之間則x返回true,但是x在11和20之間返回false。 |
IN |
IN運算符測試集成員數據。 x IN(set)表示x等於集合中的任何成員數據。 |
如果x ='m',則在('a','b','c')中x返回false,而在('m','n','o')中x返回true。 |
IS NULL |
IS NULL運算符如果其運算元為NULL返回值為TRUE,如果不為NULL則返回FALSE。 涉及NULL值的比較總是產生NULL。 |
如果x ='m',則is null'返回false 。 |
LIKE運算符
下麵的示例程式測試LIKE運算符。 在這裏使用一個小的過程procedure()來顯示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運算符的用法 -
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 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運算符
下一篇:
PL/SQL條件控制
