SQL Server中NULL的正確使用與空間占用
我們常在SQL Server的使用或維護(hù)中遇上NULL,那么什么是NULL?如下是MSDN給出的一段簡短描述(見“Null Values”):
- A value of NULL indicates that the value is unknown. A value of NULL is different from an empty or zero value. No two null values are equal. Comparisons between two null values, or between a NULL and any other value, return unknown because the value of each NULL is unknown.
通俗的講,NULL就是一個(gè)值,而且這個(gè)值是未知的(unknown);NULL不能等價(jià)任何值,甚至都不等價(jià)它自己,即NULL不等于NULL。
為了清晰的理解上述的內(nèi)容,我們創(chuàng)建一個(gè)測試表Test_NULL,然后對表插入2條含有NULL值的記錄,并進(jìn)行相關(guān)驗(yàn)證操作:
--創(chuàng)建一張?jiān)试SNULL值的表 CREATE TABLE Test_NULL ( num INT NOT NULL PRIMARY KEY ,fname NVARCHAR(50) NULL ,lname NVARCHAR(50) NULL ) --對表插入4條數(shù)據(jù):最后2條記錄含有NULL值 INSERT INTO Test_NULL (num,fname,lname) VALUES(1, 'Tom','Jane') INSERT INTO Test_NULL (num,fname,lname) VALUES(2, 'Dave','') INSERT INTO Test_NULL (num,fname) VALUES(3, 'Aaron') INSERT INTO Test_NULL (num,fname) VALUES(4, 'Betty')
為了驗(yàn)證NULL值是未知的,我們通過如下SQL查詢表Test_NULL的記錄,對lname字段進(jìn)行=操作:
--若兩個(gè)NULL是可以相等的,那么將輸出4條記錄。實(shí)際只輸出2條記錄
SELECT * FROM Test_NULL tn LEFT JOIN Test_NULL g ON tn.num = g.num WHERE tn.lname = g.lname ------------------------------------------ 1 Tom Jane 1 Tom Jane 2 Dave 2 Dave --查詢lname為''的記錄,即驗(yàn)證NULL不等于'' SELECT * FROM Test_NULL tn WHERE tn.lname = '' ------------------------------------------ 2 Dave
正確查詢/使用SQL Server中的NULL
由于NULL是未知的,因此在SQL Server默認(rèn)情況下我們不能使用=或<>去判斷或查詢一條NULL的記錄(見上述),正確的方式是:使用IS NULL或IS NOT NULL去查詢或過濾一條含有NULL的記錄。
另外有函數(shù)ISNULL(),可判斷并轉(zhuǎn)換NULL為其他值。
--通過IS NULL查詢含有NULL的記錄 SELECT * FROM Test_NULL tn WHERE tn.lname IS NULL ------------------------------------------ 3 Aaron NULL 4 Betty NULL --NULL不等于任何值,甚至NULL不等于NULL --默認(rèn)不能使用<>或=匹配NULL SELECT * FROM Test_NULL tn WHERE tn.lname <> NULL OR tn.lname = NULL ------------------------------------------
但需注意:SQL Server僅是在默認(rèn)情況下不能使用=或<>,當(dāng)設(shè)置ANSI_NULLS為OFF后,即可使用=或<>查詢NULL值
換言之,SQL Server默認(rèn)是開啟ANSI_NULLS選項(xiàng)的。
--設(shè)置ANSI_NULLS為OFF,并使用=NULL查詢記錄 SET ANSI_NULLS OFF SELECT * FROM Test_NULL tn WHERE tn.lname = NULL ------------------------------------------ 3 Aaron NULL 4 Betty NULL
插入或更新NULL值:
--插入1條含有NULL的新記錄 INSERT INTO Test_NULL (num,fname,lname) VALUES(5, 'Serena', NULL) --更新某條記錄的字段值為NULL UPDATE Test_NULL SET fname = NULL WHERE num = 2
NULL的空間占用
通常的認(rèn)識是:NULL在可變長類型(如nvarchar(50),varchar(8))中是不占用空間的,在固定長度的類型(如int)中會占用存儲空間。
實(shí)際上,上述的認(rèn)識不夠嚴(yán)謹(jǐn)。真實(shí)情況是,NULL在可變長與固定長度的類型中均會占用空間
在SQL Server非Sparse Columns中,存儲NULL的值需1個(gè)bit的NULL bitmap mask。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助。
- SQLserver查詢數(shù)據(jù)類型為ntext是空或NULL值的方法
- sqlserver對字段出現(xiàn)NULL值的處理
- sqlserver isnull在數(shù)據(jù)庫查詢中的應(yīng)用
- SQL Server、Oracle和MySQL判斷NULL的方法
- 深入SQLServer中ISNULL與NULLIF的使用詳解
- 淺談SQLServer的ISNULL函數(shù)與Mysql的IFNULL函數(shù)用法詳解
- sqlserver 不能將值NULL插入列id(列不允許有空值解決)
- SQLSERVER ISNULL 函數(shù)與判斷值是否為空的sql語句
- 在SQL Server中使用ISNULL執(zhí)行空值判斷查詢
相關(guān)文章
SQL中的游標(biāo)、異常處理、存儲函數(shù)及總結(jié)(最新推薦)
游標(biāo)(cursor)是用來存儲查詢結(jié)果集的數(shù)據(jù)類型,在存儲過程和函數(shù)中可以使用游標(biāo)對結(jié)果集進(jìn)行循環(huán)的處理,這篇文章主要介紹了SQL中的游標(biāo)、異常處理、存儲函數(shù)及總結(jié),需要的朋友可以參考下2023-02-02sqlserver 多表查詢不同數(shù)據(jù)庫服務(wù)器上的表
sqlserver中多表查詢不同數(shù)據(jù)庫服務(wù)器上的表的實(shí)現(xiàn)方法,需要的朋友可以參考下2012-04-04SQLServer 數(shù)據(jù)庫的數(shù)據(jù)匯總完全解析(WITH ROLLUP)
乍一看,好像很容易,用group by好像能實(shí)現(xiàn)?但仔細(xì)研究下去,你又會覺得group by也是無能為力,總欠缺點(diǎn)什么,無從下手。那么,到底該如何做呢?別急,SQL Server早就幫我們做好了,下面,跟我來。2010-09-09sqlserver 巧妙的自關(guān)聯(lián)運(yùn)用
最近在改報(bào)表分頁,遇到一個(gè)很棘手的問題,需要將比較正常的數(shù)據(jù)記錄新增加兩列2012-07-07SQLSERVER ip地址改別名的實(shí)現(xiàn)示例
本文介紹了如何將SQLSERVER的IP地址改為別名,以方便網(wǎng)絡(luò)訪問和管理,通過修改HOSTS文件或DNS解析,這樣不僅可以提高網(wǎng)絡(luò)連接的穩(wěn)定性和可靠性,還可以方便管理員進(jìn)行遠(yuǎn)程管理和維護(hù)2023-08-08Sql Server Management Studio連接Mysql的實(shí)現(xiàn)步驟
本文主要介紹了Sql Server Management Studio連接Mysql的實(shí)現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04