新聞中心
當(dāng)使用 SELECT 語句進(jìn)行查詢時(shí), MySQL 允許用戶對(duì)表達(dá)式的左邊操作數(shù)和右邊操作數(shù)進(jìn)行比較,比較結(jié)果為真,則返回 1,為假則返回 0,比較結(jié)果不確定則返回 NULL。MySQL 支持的比較運(yùn)算符如下表所示。

太湖網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)公司!從網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、成都響應(yīng)式網(wǎng)站建設(shè)等網(wǎng)站項(xiàng)目制作,到程序開發(fā),運(yùn)營維護(hù)。創(chuàng)新互聯(lián)公司成立于2013年到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)公司。
| 運(yùn)算符 | 作用 |
|---|---|
| = | 等于 |
| <=> | 安全的等于 |
| <> 或者 != | 不等于 |
| <= | 小于等于 |
| >= | 大于等于 |
| > | 大于 |
| IS NULL 或者 ISNULL | 判斷一個(gè)值是否為空 |
| IS NOT NULL | 判斷一個(gè)值是否不為空 |
| BETWEEN AND | 判斷一個(gè)值是否落在兩個(gè)值之間 |
比較運(yùn)算符可以用于比較數(shù)字、字符串和表達(dá)式的值。注意,字符串的比較是不區(qū)分大小寫的。
1) 等于運(yùn)算(=)
= 運(yùn)算符用來比較兩邊的操作數(shù)是否相等,相等的話返回 1,不相等的話返回 0。具體的語法規(guī)則如下:
- 若有一個(gè)或兩個(gè)操作數(shù)為 NULL,則比較運(yùn)算的結(jié)果為 NULL。
- 若兩個(gè)操作數(shù)都是字符串,則按照字符串進(jìn)行比較。
- 若兩個(gè)操作數(shù)均為整數(shù),則按照整數(shù)進(jìn)行比較。
- 若一個(gè)操作數(shù)為字符串,另一個(gè)操作數(shù)為數(shù)字,則 MySQL 可以自動(dòng)將字符串轉(zhuǎn)換為數(shù)字。
注意:NULL 不能用于 = 比較。
【實(shí)例1】使用 = 進(jìn)行相等判斷,SQL 語句如下:
mysql> SELECT 1=0,'2'=2,2=2,'0.02'=0,'b'='b',(1+3)=(2+2),NULL=null; +-----+-------+-----+----------+---------+-------------+-----------+ | 1=0 | '2'=2 | 2=2 | '0.02'=0 | 'b'='b' | (1+3)=(2+2) | NULL=null | +-----+-------+-----+----------+---------+-------------+-----------+ | 0 | 1 | 1 | 0 | 1 | 1 | NULL | +-----+-------+-----+----------+---------+-------------+-----------+ 1 row in set (0.01 sec)
對(duì)運(yùn)行結(jié)果的分析:
-
2=2和'2' =2的返回值相同,都為 1,因?yàn)樵谶M(jìn)行判斷時(shí),MySQL 自動(dòng)進(jìn)行了轉(zhuǎn)換,把字符 '2' 轉(zhuǎn)換成了數(shù)字 2。 -
'b'='b'為相同的字符比較,因此返回值為 1。 - 表達(dá)式
1+3和表達(dá)式2+2的結(jié)果都為 4,因此結(jié)果相等,返回值為 1; - 由于 = 不能用于空值 NULL 的判斷,因此
NULL=null的返回值為 NULL。
2) 安全等于運(yùn)算符(<=>)
<=> 操作符和 = 操作符類似,不過 <=> 可以用來判斷 NULL 值,具體語法規(guī)則為:
- 當(dāng)兩個(gè)操作數(shù)均為 NULL 時(shí),其返回值為 1 而不為 NULL;
- 而當(dāng)一個(gè)操作數(shù)為 NULL 時(shí),其返回值為 0 而不為 NULL。
【實(shí)例2】使用 <=> 進(jìn)行相等的判斷,SQL 語句如下:
mysql> SELECT 1<=>0,'2'<=>2,2<=>2,'0.02'<=>0,'b'<=>'b',(1+3) <=> (2+1),NULL<=>NULL;
+-------+---------+-------+------------+-----------+-----------------+-------------+
| 1<=>0 | '2'<=>2 | 2<=>2 | '0.02'<=>0 | 'b'<=>'b' | (1+3) <=> (2+1) | NULL<=>NULL |
+-------+---------+-------+------------+-----------+-----------------+-------------+
| 0 | 1 | 1 | 0 | 1 | 0 | 1 |
+-------+---------+-------+------------+-----------+-----------------+-------------+
1 row in set (0.00 sec)
由結(jié)果可以看到,<=> 在執(zhí)行比較操作時(shí)和 = 的作用是相似的,唯一的區(qū)別是 <=> 可以用來對(duì) NULL 進(jìn)行判斷,兩者都為 NULL 時(shí)返回值為 1。
3) 不等于運(yùn)算符(<> 或者 !=)
與 = 的作用相反,<> 和 != 用于判斷數(shù)字、字符串、表達(dá)式是否不相等。對(duì)于 <> 和 !=,如果兩側(cè)操作數(shù)不相等,返回值為 1,否則返回值為 0;如果兩側(cè)操作數(shù)有一個(gè)是 NULL,那么返回值也是 NULL。
【實(shí)例3】使用 <> 和 != 進(jìn)行不相等的判斷,SQL 語句如下:
mysql> SELECT 'good'<>'god',1<>2,4!=4,5.5!=5,(1+3)!=(2+1),NULL<>NULL; +---------------+------+------+--------+--------------+------------+ | 'good'<>'god' | 1<>2 | 4!=4 | 5.5!=5 | (1+3)!=(2+1) | NULL<>NULL | +---------------+------+------+--------+--------------+------------+ | 1 | 1 | 0 | 1 | 1 | NULL | +---------------+------+------+--------+--------------+------------+ 1 row in set (0.00 sec)
由結(jié)果可以看到,兩個(gè)不等于運(yùn)算符作用相同,都可以進(jìn)行數(shù)字、字符串、表達(dá)式的比較判斷。
4) 小于等于運(yùn)算符(<=)
<= 是小于等于運(yùn)算符,用來判斷左邊的操作數(shù)是否小于或者等于右邊的操作數(shù);如果小于或者等于,返回值為 1,否則返回值為 0;如果兩側(cè)操作數(shù)有一個(gè)是 NULL,那么返回值也是 NULL。
【實(shí)例4】使用 <= 進(jìn)行比較判斷,SQL 語句如下:
mysql> SELECT 'good'<='god',1<=2,4<=4,5.5<=5,(1+3)<=(2+1),NULL<=NULL; +---------------+------+------+--------+--------------+------------+ | 'good'<='god' | 1<=2 | 4<=4 | 5.5<=5 | (1+3)<=(2+1) | NULL<=NULL | +---------------+------+------+--------+--------------+------------+ | 0 | 1 | 1 | 0 | 0 | NULL | +---------------+------+------+--------+--------------+------------+ 1 row in set (0.00 sec)
由結(jié)果可以看到:
- 左邊操作數(shù)小于或者等于右邊時(shí),返回值為 1,例如 4<=4;
- 當(dāng)左邊操作數(shù)大于右邊時(shí),返回值為 0,例如“good”第 3 個(gè)位置的“o”字符在字母表中的順序大于“god”中的第 3 個(gè)位置的“d”字符,因此返回值為0;
- 同樣,比較 NULL 值時(shí)返回 NULL。
5) 小于運(yùn)算符(<)
< 是小于運(yùn)算符,用來判斷左邊的操作數(shù)是否小于右邊的操作數(shù);如果小于,返回值為 1,否則返回值為 0;如果兩側(cè)操作數(shù)有一個(gè)是 NULL,那么返回值也是 NULL。
【實(shí)例5】使用 < 進(jìn)行比較判斷,SQL 語句如下:
mysql> SELECT 'good'<'god',1<2,4<4,5.5<5,(1+3)<(2+1),NULL由結(jié)果可以看到:
- 當(dāng)左邊操作數(shù)小于右邊時(shí),返回值為 1,例如 1<2;
- 當(dāng)左邊操作數(shù)大于右邊時(shí),返回值為 0,例如“good”第 3 個(gè)位置的“o”字符在字母表中的順序大于“god”中的第 3 個(gè)位置的“d”字符,因此返回值為 0;
- 同樣,比較 NULL 值時(shí)返回 NULL。
6) 大于等于運(yùn)算符(>=)
>= 是大于等于運(yùn)算符,用來判斷左邊的操作數(shù)是否大于或者等于右邊的操作數(shù);如果大于或者等于,返回值為 1,否則返回值為 0;如果兩側(cè)操作數(shù)有一個(gè)是 NULL,那么返回值也是 NULL。
【實(shí)例6】使用 >= 進(jìn)行比較判斷,SQL 語句如下:
mysql> SELECT 'good'>='god',1>=2,4>=4,5.5>=5,(1+3)>=(2+1),NULL>=NULL; +---------------+------+------+--------+--------------+------------+ | 'good'>='god' | 1>=2 | 4>=4 | 5.5>=5 | (1+3)>=(2+1) | NULL>=NULL | +---------------+------+------+--------+--------------+------------+ | 1 | 0 | 1 | 1 | 1 | NULL | +---------------+------+------+--------+--------------+------------+ 1 row in set (0.00 sec)由結(jié)果可以看到:
- 左邊操作數(shù)大于或者等于右邊時(shí),返回值為 1,例如 4>=4;
- 當(dāng)左邊操作數(shù)小于右邊時(shí),返回值為 0,例如 1>=2;
- 同樣,比較 NULL 值時(shí)返回 NULL。
7) 大于運(yùn)算符(>)
> 是大于運(yùn)算符,用來判斷左邊的操作數(shù)是否大于右邊的操作數(shù);如果大于,返回值為 1,否則返回值為 0;如果兩側(cè)操作數(shù)有一個(gè)是 NULL,那么返回值也是 NULL。
【實(shí)例7】使用 > 進(jìn)行比較判斷,SQL 語句如下:
mysql> SELECT 'good'>'god',1>2,4>4,5.5>5,(1+3)>(2+1),NULL>NULL; +--------------+-----+-----+-------+-------------+-----------+ | 'good'>'god' | 1>2 | 4>4 | 5.5>5 | (1+3)>(2+1) | NULL>NULL | +--------------+-----+-----+-------+-------------+-----------+ | 1 | 0 | 0 | 1 | 1 | NULL | +--------------+-----+-----+-------+-------------+-----------+ 1 row in set (0.00 sec)由結(jié)果可以看到:
- 左邊操作數(shù)大于右邊時(shí),返回值為 1,例如 5.5>5;
- 當(dāng)左邊操作數(shù)小于右邊時(shí),返回 0,例如 1>2;
- 同樣,比較 NULL 值時(shí)返回 NULL。
8) IS NULL(ISNULL) 和 IS NOT NULL 運(yùn)算符
IS NULL 或 ISNULL 運(yùn)算符用來檢測一個(gè)值是否為 NULL,如果為 NULL,返回值為 1,否則返回值為 0。ISNULL 可以認(rèn)為是 IS NULL 的簡寫,去掉了一個(gè)空格而已,兩者的作用和用法都是完全相同的。
IS NOT NULL 運(yùn)算符用來檢測一個(gè)值是否為非 NULL,如果是非 NULL,返回值為 1,否則返回值為 0。
【實(shí)例8】使用 IS NULL、ISNULL 和 IS NOT NULL 判斷 NULL 值和非 NULL 值,SQL 語句如下:
mysql> SELECT NULL IS NULL,ISNULL(NULL),ISNULL(10),10 IS NOT NULL; +--------------+--------------+------------+----------------+ | NULL IS NULL | ISNULL(NULL) | ISNULL(10) | 10 IS NOT NULL | +--------------+--------------+------------+----------------+ | 1 | 1 | 0 | 1 | +--------------+--------------+------------+----------------+ 1 row in set (0.01 sec)由結(jié)果可以看到,IS NULL 和 ISNULL 的作用相同,只是寫法略有不同。ISNULL 和 IS NOT NULL 的返回值正好相反。
9) BETWEEN AND 運(yùn)算符
BETWEEN AND 運(yùn)算符用來判斷表達(dá)式的值是否位于兩個(gè)數(shù)之間,或者說是否位于某個(gè)范圍內(nèi),它的語法格式如下:
expr BETWEEN min AND max
expr 表示要判斷的表達(dá)式,min 表示最小值,max 表示最大值。如果 expr 大于等于 min 并且小于等于 max,那么返回值為 1,否則返回值為 0。
【實(shí)例9】使用 BETWEEN AND 進(jìn)行值區(qū)間判斷,輸入 SQL 語句如下:
mysql> SELECT 4 BETWEEN 2 AND 5,4 BETWEEN 4 AND 6,12 BETWEEN 9 AND 10; +-------------------+-------------------+---------------------+ | 4 BETWEEN 2 AND 5 | 4 BETWEEN 4 AND 6 | 12 BETWEEN 9 AND 10 | +-------------------+-------------------+---------------------+ | 1 | 1 | 0 | +-------------------+-------------------+---------------------+ 1 row in set (0.00 sec)由結(jié)果可以看到:
- 4 在端點(diǎn)值區(qū)間內(nèi)或者等于其中一個(gè)端點(diǎn)值,BETWEEN AND 表達(dá)式返回值為 1;
- 12 并不在指定區(qū)間內(nèi),因此返回值為 0;
- 對(duì)于字符串類型的比較,按字母表中字母順序進(jìn)行比較,“x”不在指定的字母區(qū)間內(nèi),因此返回值為 0,而“b”位于指定字母區(qū)間內(nèi),因此返回值為 1。
總結(jié)
使用比較運(yùn)算符時(shí)需要注意空值 NULL,大部分比較運(yùn)算符遇到 NULL 時(shí)也會(huì)返回 NULL,上面我們都進(jìn)行了說明。
另外,有些教程把 IN 和 NOT IN 也劃分為比較運(yùn)算符,但是我并不這樣認(rèn)為,我認(rèn)為它們的初衷是判斷某個(gè)值是否位于給出的列表中,只是使用了比較的功能而已,讀者可以猛擊《 MySQL IN和NOT IN用法詳解》一文了解更多。
名稱欄目:創(chuàng)新互聯(lián)數(shù)據(jù)庫教程:MySQL比較運(yùn)算符一覽表(帶解析)
網(wǎng)站地址:http://m.fisionsoft.com.cn/article/dhgsees.html


咨詢
建站咨詢
