日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

13、MySQL比较运算符

發布時間:2025/3/20 数据库 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 13、MySQL比较运算符 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

當使用 SELECT 語句進行查詢時,MySQL 允許用戶對表達式的左邊操作數和右邊操作數進行比較,比較結果為真,則返回 1,為假則返回 0,比較結果不確定則返回 NULL。MySQL 支持的比較運算符如下表所示。

運算符作用
=等于
<=>安全的等于
<>或者 != 不等于
<=小于等于
>=大于等于
>大于
IS NULL 或者 ISNULL判斷一個值是否為空
IS NOT NULL判斷一個值是否不為空
BETWEEN AND判斷一個值是否落在兩個值之間

比較運算符可以用于比較數字、字符串和表達式的值。注意,字符串的比較是不區分大小寫的。

1) 等于運算(=)

= 運算符用來比較兩邊的操作數是否相等,相等的話返回 1,不相等的話返回 0。具體的語法規則如下:

  • 若有一個或兩個操作數為 NULL,則比較運算的結果為 NULL。
  • 若兩個操作數都是字符串,則按照字符串進行比較。
  • 若兩個操作數均為整數,則按照整數進行比較。
  • 若一個操作數為字符串,另一個操作數為數字,則 MySQL 可以自動將字符串轉換為數字。

注意:NULL 不能用于 = 比較。

【實例1】使用 = 進行相等判斷,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 | +-----+-------+-----+----------+---------+-------------+-----------+

對運行結果的分析:

  • 2=2和’2’ =2的返回值相同,都為 1,因為在進行判斷時,MySQL 自動進行了轉換,把字符 ‘2’ 轉換成了數字 2。
  • ‘b’='b’為相同的字符比較,因此返回值為 1。
  • 表達式1+3和表達式2+2的結果都為 4,因此結果相等,返回值為 1;
  • 由于 = 不能用于空值 NULL 的判斷,因此NULL=null的返回值為 NULL。

2) 安全等于運算符(<=>)

<=> 操作符和 = 操作符類似,不過 <=> 可以用來判斷 NULL 值,具體語法規則為:

  • 當兩個操作數均為 NULL 時,其返回值為 1 而不為 NULL;
  • 而當一個操作數為 NULL 時,其返回值為 0 而不為 NULL。

【實例2】使用 <=> 進行相等的判斷,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 | +-------+---------+-------+------------+-----------+-----------------+-------------+

由結果可以看到,<=> 在執行比較操作時和 = 的作用是相似的,唯一的區別是 <=> 可以用來對 NULL 進行判斷,兩者都為 NULL 時返回值為 1。

3) 不等于運算符(<> 或者 !=)

與 = 的作用相反,<> 和 != 用于判斷數字、字符串、表達式是否不相等。對于 <> 和 !=,如果兩側操作數不相等,返回值為 1,否則返回值為 0;如果兩側操作數有一個是 NULL,那么返回值也是 NULL。

【實例3】使用 <> 和 != 進行不相等的判斷,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 | +---------------+------+------+--------+--------------+------------+

由結果可以看到,兩個不等于運算符作用相同,都可以進行數字、字符串、表達式的比較判斷。

4) 小于等于運算符(<=)

<= 是小于等于運算符,用來判斷左邊的操作數是否小于或者等于右邊的操作數;如果小于或者等于,返回值為 1,否則返回值為 0;如果兩側操作數有一個是 NULL,那么返回值也是 NULL。

【實例4】使用 <= 進行比較判斷,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,例如 4<=4;
  • 當左邊操作數大于右邊時,返回值為 0,例如“good”第 3 個位置的“o”字符在字母表中的順序大于“god”中的第 3
    個位置的“d”字符,因此返回值為0;
  • 同樣,比較 NULL 值時返回 NULL。

5) 小于運算符(<)

< 是小于運算符,用來判斷左邊的操作數是否小于右邊的操作數;如果小于,返回值為 1,否則返回值為 0;如果兩側操作數有一個是 NULL,那么返回值也是 NULL。

【實例5】使用 < 進行比較判斷,SQL 語句如下:

mysql> SELECT 'good'<'god'1<24<45.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 | 0 | 0 | 0 | NULL | +--------------+-----+-----+-------+-------------+-----------+

由結果可以看到:

  • 當左邊操作數小于右邊時,返回值為 1,例如 1<2;
  • 當左邊操作數大于右邊時,返回值為 0,例如“good”第 3 個位置的“o”字符在字母表中的順序大于“god”中的第 3
    個位置的“d”字符,因此返回值為 0;
  • 同樣,比較 NULL 值時返回 NULL。

6) 大于等于運算符(>=)

>= 是大于等于運算符,用來判斷左邊的操作數是否大于或者等于右邊的操作數;如果大于或者等于,返回值為 1,否則返回值為 0;如果兩側操作數有一個是 NULL,那么返回值也是 NULL。

【實例6】使用 >= 進行比較判斷,SQL 語句如下:

mysql> SELECT 'good'>='god'1>=24>=45.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,例如 4>=4;
  • 當左邊操作數小于右邊時,返回值為 0,例如 1>=2;
  • 同樣,比較 NULL 值時返回 NULL。

7) 大于運算符(>)

> 是大于運算符,用來判斷左邊的操作數是否大于右邊的操作數;如果大于,返回值為 1,否則返回值為 0;如果兩側操作數有一個是 NULL,那么返回值也是 NULL。

【實例7】使用 > 進行比較判斷,SQL 語句如下: mysql> SELECT 'good'>'god'1>24>45.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,例如 5.5>5;
  • 當左邊操作數小于右邊時,返回 0,例如 1>2;
  • 同樣,比較 NULL 值時返回 NULL。

8) IS NULL(ISNULL) 和 IS NOT NULL 運算符

IS NULL 或 ISNULL 運算符用來檢測一個值是否為 NULL,如果為 NULL,返回值為 1,否則返回值為 0。ISNULL 可以認為是 IS NULL 的簡寫,去掉了一個空格而已,兩者的作用和用法都是完全相同的。

IS NOT NULL 運算符用來檢測一個值是否為非 NULL,如果是非 NULL,返回值為 1,否則返回值為 0。

【實例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 | +--------------+--------------+------------+----------------+

由結果可以看到,IS NULL 和 ISNULL 的作用相同,只是寫法略有不同。ISNULL 和 IS NOT NULL 的返回值正好相反。

9) BETWEEN AND 運算符

BETWEEN AND 運算符用來判斷表達式的值是否位于兩個數之間,或者說是否位于某個范圍內,它的語法格式如下:

expr BETWEEN min AND max

expr 表示要判斷的表達式,min 表示最小值,max 表示最大值。如果 expr 大于等于 min 并且小于等于 max,那么返回值為 1,否則返回值為 0。

【實例9】使用 BETWEEN AND 進行值區間判斷,輸入 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 | +-------------------+-------------------+---------------------+

由結果可以看到:

  • 4 在端點值區間內或者等于其中一個端點值,BETWEEN AND 表達式返回值為 1;
  • 12 并不在指定區間內,因此返回值為 0;
  • 對于字符串類型的比較,按字母表中字母順序進行比較,“x”不在指定的字母區間內,因此返回值為 0,而“b”位于指定字母區間內,因此返回值為1。

總結

使用比較運算符時需要注意空值 NULL,大部分比較運算符遇到 NULL 時也會返回 NULL,上面我們都進行了說明。

總結

以上是生活随笔為你收集整理的13、MySQL比较运算符的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。