亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > 文庫 > 正文

SQL中IS NOT NULL與!=NULL的區別

2020-10-29 21:49:36
字體:
來源:轉載
供稿:網友

平時經常會遇到這兩種寫法:IS NOT NULL與!=NULL。也經常會遇到數據庫有符合條件!=NULL的數據,但是返回為空集合。實際上,是由于對二者使用區別理解不透徹。

默認情況下,推薦使用 IS NOT NULL去做條件判斷,因為SQL默認情況下對WHERE XX!= Null的判斷會永遠返回0行,卻不會提示語法錯誤。

這是為什么呢?

SQL Server文檔中對Null值的比較運算定義了兩種規則,如在SQL Server 2000中:

規則一是是ANSISQL(SQL-92)規定的Null值的比較取值結果都為False,既Null=Null取值也是False。另一種不準循ANSISQL標準,即Null=Null為True。:

例如數據表test結構:

復制代碼 代碼如下:

ROWNUM     DATA
-------------------
1     'Liu Yang'
2     Null
3     '12345'

按照ANSI SQL標準,下面的兩個查詢都不返回任何行:

查詢一: SELECT * FROM test WHERE data=NULL
查詢二: SELECT * FROM test WHERE data<>NULL

而按照非ANSI SQL標準,查詢1將返回第二行,查詢2返回1、3行。

這是因為在SQL中,NULL是一種特有的數據類型,其等價于沒有任何值、是未知數。NULL與0、空字符串、空格都不同。
ANSI SQL標準中取得Null值的行需要用下面的查詢:

復制代碼 代碼如下:

SELECT * FROM test WHERE data IS NULL

由此可見非ANSI SQL標準中data=NULL等同于data IS NULL,data<>NULL等同于data IS NOT NULL。

所以我們要牢記:默認情況下做比較條件時使用關鍵字“is null”和“is not null”。

如果你一定要使用!= null來進行條件判斷,需要加上這個命令語句:SET ANSI_NULLS OFF,這時數據庫進入ANSI SQL非標準模式,你會發現IS NOT NULL 和 != null 是等效的了。

這里使用的是模式切換命令SET ANSI_NULLS[ON/OFF]。ON值采用ANSI SQL嚴格標準,OFF值采用非標準兼容模式。另外SET ANSI_DEFAULTS [ON/OFF]命令也可以實現標準的切換,只是這個命令控制的是一組符合SQL-92標準的設置,其中就包括Null值的標準。

默認情況下,數據庫管理程序(DB-Library)是SET ANSI_NULLS為OFF的。但是我們的大多數應用程序,都是通過ODBC或者OLEDB來訪問數據庫的,作為一種開放兼容的數據庫訪問程序,或許是兼容性的考慮,SETANSI_NULLS值設置為ON。這樣一來帶來的一些問題是需要注意的。像存儲過程或者自定義函數這樣的應用程序都是基于DB-Library的,默認情況下,SETANSI_NULLS為OFF,并且在這樣的程序中,不能使用SETANSI_NULLS在一個環境中修改規則,只能修改數據庫配置參數。

例如下面這種情況:你的應用程序使用ADODB來訪問數據庫,采用OleDb或者ODBC數據提供程序。對于查詢一: SELECT * FROM test WHERE data=NULL
我們可以直接發送命令取得查詢結果集,也可把它放到存儲過程當中。但二者查詢結果不同。若直接使用查詢命令,不返回任何行;而如果訪問存儲過程,返回第2行的數據。

最后,我們再次聲明:數據庫默認情況下,做SQL條件查詢比較時使用關鍵字“is null”和“is not null”。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产视频精品久久久| 91高潮在线观看| 久久国产精品久久久久久| 97视频在线观看免费高清完整版在线观看| 亚洲精品福利免费在线观看| 日韩在线观看成人| 国产精品视频xxx| 久久久久久久亚洲精品| 欧美日韩国产二区| 日韩免费在线电影| 欧美精品午夜视频| 午夜精品久久久久久久99热浪潮| 欧美最猛性xxxxx免费| 2021久久精品国产99国产精品| 亚洲色图25p| 在线看日韩av| 国产精品福利小视频| 91在线视频导航| 久久久久一本一区二区青青蜜月| 成人福利在线观看| 精品毛片三在线观看| 国产美女高潮久久白浆| 高清欧美一区二区三区| 性色av一区二区三区在线观看| 中文字幕国产日韩| 亚洲精品福利资源站| 日韩中文字幕在线观看| 欧美在线www| 日韩欧美国产中文字幕| 国产美女91呻吟求| 日韩av大片在线| 国产精品国产三级国产aⅴ浪潮| 日本成人激情视频| 97久久国产精品| 俺也去精品视频在线观看| 在线成人一区二区| 久色乳综合思思在线视频| 亚洲一区二区三区视频播放| 久久av红桃一区二区小说| 92版电视剧仙鹤神针在线观看| 91九色国产在线| 色综合视频网站| 亲爱的老师9免费观看全集电视剧| 2021国产精品视频| 国产一区二区av| 日韩av在线网址| 久久久久久久网站| 日韩av成人在线| 国产精品女主播视频| 伊人av综合网| 国产在线播放91| 96国产粉嫩美女| 97视频com| 亚洲精品456在线播放狼人| 亚洲最新av在线网站| 成人午夜一级二级三级| 亚洲free性xxxx护士hd| 92看片淫黄大片看国产片| 欧美激情精品久久久久久变态| 亚洲精品在线看| 色婷婷av一区二区三区在线观看| 啊v视频在线一区二区三区| 亚洲网站在线播放| 国产精品视频一区国模私拍| 亚洲精品日韩丝袜精品| 色婷婷av一区二区三区久久| 精品欧美一区二区三区| 亚洲成人av在线播放| 欧美电影免费在线观看| 高清欧美性猛交xxxx| 国产精品自产拍高潮在线观看| 一个人看的www久久| 中文字幕一区二区三区电影| 亚洲人成电影在线| 亚洲国产精品大全| 中文字幕一区电影| 久久精品视频播放| 欧美俄罗斯性视频| 97av在线影院| 欧美激情va永久在线播放| 国产精品久久一区主播| 91av成人在线| 亚洲理论在线a中文字幕| 久久久精品一区二区三区| 久久人人爽人人爽人人片亚洲| 成人黄色影片在线| 亚洲国产精品高清久久久| 亚洲自拍偷拍网址| 97国产精品人人爽人人做| 欧美激情视频播放| 国产精品www网站| 欧美日韩另类在线| 欧美乱大交xxxxx另类电影| 亚洲精品国产欧美| 海角国产乱辈乱精品视频| 狠狠色噜噜狠狠狠狠97| 姬川优奈aav一区二区| 国产不卡视频在线| 国产精品成人免费电影| 日本高清视频一区| 久久99精品国产99久久6尤物| 亚洲国产精品99久久| 色老头一区二区三区| 91tv亚洲精品香蕉国产一区7ujn| 欧美中文字幕在线播放| 日韩电视剧在线观看免费网站| 精品国产福利视频| 欧美日韩福利在线观看| 日韩视频在线观看免费| 国产精品久久久久久久av电影| 欧美性极品xxxx做受| 日韩av免费在线观看| 91精品国产自产在线| 日韩激情av在线播放| 成人在线视频网站| 日韩av观看网址| 在线观看国产精品91| 国产精品自产拍高潮在线观看| 国语自产偷拍精品视频偷| 欧美激情高清视频| 日韩一区二区三区在线播放| 精品爽片免费看久久| 国产亚洲欧洲黄色| 久久精品成人欧美大片古装| 日韩视频免费观看| 日韩美女免费视频| 日韩欧美国产一区二区| 国产日韩欧美日韩大片| 尤物yw午夜国产精品视频明星| 久久精品国产清自在天天线| 国产精品视频免费在线观看| 日韩电影中文 亚洲精品乱码| 成人黄色在线播放| 亚洲人av在线影院| 国产视频精品va久久久久久| 欧美激情免费在线| 亚洲国产日韩欧美综合久久| 欧美精品国产精品日韩精品| 亚洲精品国产综合区久久久久久久| 欧美亚洲国产日韩2020| 成人黄色免费片| 欧美视频二区36p| 国内精品久久久久久久| 国产区精品视频| 欧美裸体男粗大视频在线观看| 午夜精品久久久久久久男人的天堂| 亚洲精选在线观看| 精品久久久国产精品999| 不卡在线观看电视剧完整版| 日韩一二三在线视频播| 精品久久久一区| 久久精品美女视频网站| 亚洲国产精彩中文乱码av在线播放| 国产日韩精品电影| 久久视频中文字幕| 亚洲成色777777在线观看影院| 伊人久久久久久久久久久| 日韩精品极品视频免费观看| 欧美精品激情视频| 亚洲精品网站在线播放gif| 欧美日韩国产中文精品字幕自在自线| 国产精品视频一区二区高潮| 国产91热爆ts人妖在线| 91精品美女在线|