比較運算符用于將一個表達(dá)式與另一個表達(dá)式作比較。結(jié)果始終為TRUE,F(xiàn)ALSE或NULL。
運算符 | 描述 | 示例 |
---|---|---|
LIKE |
LIKE 運算符將字符,字符串或CLOB 值與模式進(jìn)行比較,如果值與模式匹配,則返回TRUE ,否則返回FALSE 。 |
如果'Zara Ali' LIKE 'Z%A_i' 返回一個布爾值true ,而'Nuha Ali' LIKE'Z%A_i' 返回一個布爾值。 |
BETWEEN |
BETWEEN 運算符測試值是否在指定范圍內(nèi)。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 運算符測試集成員數(shù)據(jù)。 x IN(set) 表示x 等于集合中的任何成員數(shù)據(jù)。 |
如果x ='m' ,則在('a','b','c') 中x 返回false ,而在('m','n','o') 中x 返回true 。 |
IS NULL |
IS NULL 運算符如果其操作數(shù)為NULL 返回值為TRUE ,如果不為NULL 則返回FALSE 。 涉及NULL 值的比較總是產(chǎn)生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
當(dāng)上述代碼在SQL提示下執(zhí)行后,會產(chǎn)生以下結(jié)果 -
True
False
PL/SQL procedure successfully completed.
Shell
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
當(dāng)上述代碼在SQL提示符下執(zhí)行時,它會產(chǎn)生以下結(jié)果 -
True
True
False
PL/SQL procedure successfully completed.
SQL
以下程序顯示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
當(dāng)上述代碼在SQL提示符下執(zhí)行時,它會產(chǎn)生以下結(jié)果 -
False
True
False
PL/SQL procedure successfully completed.
更多建議: