16、IN和NOT IN用法详解
生活随笔
收集整理的這篇文章主要介紹了
16、IN和NOT IN用法详解
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
MySQL 中的 IN 運算符用來判斷表達式的值是否位于給出的列表中;如果是,返回值為 1,否則返回值為 0。
NOT IN 的作用和 IN 恰好相反,NOT IN 用來判斷表達式的值是否不存在于給出的列表中;如果不是,返回值為 1,否則返回值為 0。
IN的語法格式如下:
expr IN ( value1, value2, value3 ... valueN )NOT IN的語法格式如下:
expr NOT IN ( value1, value2, value3 ... valueN )expr 表示要判斷的表達式,value1, value2, value3 … valueN 表示列表中的值。MySQL 會將 expr 的值和列表中的值逐一對比。
【實例1】在 SQL 語句中使用 IN 和 NOT IN 運算符:
mysql> SELECT 2 IN (1,3,5,'thks'),'thks' IN (1,3,5, 'thks'); +---------------------+---------------------------+ | 2 IN (1,3,5,'thks') | 'thks' IN (1,3,5, 'thks') | +---------------------+---------------------------+ | 0 | 1 | +---------------------+---------------------------+ mysql> SELECT 2 NOT IN (1,3,5,'thks'),'thks' NOT IN (1,3,5, 'thks'); +-------------------------+-------------------------------+ | 2 NOT IN (1,3,5,'thks') | 'thks' NOT IN (1,3,5, 'thks') | +-------------------------+-------------------------------+ | 1 | 0 | +-------------------------+-------------------------------+由結果可以看到,IN 和 NOT IN 的返回值正好相反。
對空值 NULL 的處理
當 IN 運算符的兩側有一個為空值 NULL 時,如果找不到匹配項,則返回值為 NULL;如果找到了匹配項,則返回值為 1。
請看下面的 SQL 語句如下:
mysql> SELECT NULL IN (1,3,5,'thks'),10 IN (1,3,NULL,'thks'); +------------------------+-------------------------+ | NULL IN (1,3,5,'thks') | 10 IN (1,3,NULL,'thks') | +------------------------+-------------------------+ | NULL | NULL | +------------------------+-------------------------+ mysql> SELECT NULL IN (1,3,5,'thks'),10 IN (1,10,NULL,'thks'); +------------------------+--------------------------+ | NULL IN (1,3,5,'thks') | 10 IN (1,10,NULL,'thks') | +------------------------+--------------------------+ | NULL | 1 | +------------------------+--------------------------+NOT IN 恰好相反,當 NOT IN 運算符的兩側有一個為空值 NULL 時,如果找不到匹配項,則返回值為 NULL;如果找到了匹配項,則返回值為 0。
請看下面的 SQL 語句如下:
mysql> SELECT NULL NOT IN (1,3,5,'thks'),10 NOT IN (1,0,NULL,'thks'); +----------------------------+-----------------------------+ | NULL NOT IN (1,3,5,'thks') | 10 NOT IN (1,0,NULL,'thks') | +----------------------------+-----------------------------+ | NULL | NULL | +----------------------------+-----------------------------+ mysql> SELECT NULL NOT IN (1,3,5,'thks'),10 NOT IN (1,10,NULL,'thks'); +----------------------------+------------------------------+ | NULL NOT IN (1,3,5,'thks') | 10 NOT IN (1,10,NULL,'thks') | +----------------------------+------------------------------+ | NULL | 0 | +----------------------------+------------------------------+總結
以上是生活随笔為你收集整理的16、IN和NOT IN用法详解的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 15、MySQL运算符的优先级
- 下一篇: 1、SELECT:数据表查询语句