MySQL的空值和NULL有什么區別?(附示例)

本篇文章給大家帶來的內容是關于mysql的空值和NULL有什么區別?(附示例),有一定的參考價值,有需要的朋友可以參考一下,希望對你有所幫助。

從本質上區別

1、空值不占空間

2、null值占空間

通俗的講:

空值就像是一個真空轉態杯子,什么都沒有,而null值就是一個裝滿空氣的杯子,雖然看起來都是一樣的,但是有著本質的區別。

(推薦課程:MySQL教程

例子:

創建一個test表,colA是不可以存放null值的,colB是能存放null值的。

CREATE?TABLE?`test`?( ???`colA`?varchar(255)?NOT?NULL, ???`colB`?varchar(255)?DEFAULT?NULL ?)?ENGINE=InnoDB?DEFAULT?CHARSET=utf8;

插入一個null值試試,會發生什么情況?

INSERT?INTO?`test`(`colA`,?`colB`)?VALUES?(NULL,?NULL);

//出現報錯,原因是colA是不能插入null值。

MySQL的空值和NULL有什么區別?(附示例)MySQL的空值和NULL有什么區別?(附示例)

那么如果兩個字段同時插入空值,會怎么樣。

INSERT?INTO?`test`(`colA`,?`colB`)?VALUES?('',?'');

插入成功,說明字段即使設置為null值的時候,是可以插入空值的

?MySQL的空值和NULL有什么區別?(附示例)

—————————————————————查詢———————————————————

現在表里有三條數據

?MySQL的空值和NULL有什么區別?(附示例)

接下來我們使用 is not null 和 檢索數據表里的數據

1、使用IS NOT NULL 的查詢

1?SELECT?*?FROM?`test`?WHERE?colA?IS?NOT?NULL

MySQL的空值和NULL有什么區別?(附示例)

1?SELECT?*?FROM?`test`?WHERE?colB?IS?NOT?NULL

MySQL的空值和NULL有什么區別?(附示例)

結論:使用 IS NOT NULL 查詢不會過濾空值,但是會過濾掉NULL。

2、使用 的查詢

1?SELECT?*?FROM?`test`?WHERE?colA??'';

MySQL的空值和NULL有什么區別?(附示例)

1?SELECT?*?FROM?`test`?WHERE?colA??'';

MySQL的空值和NULL有什么區別?(附示例)

結論:使用 會過濾掉NULL和空值。

3、使用 count 查詢

1?SELECT?COUNT(colA)?FROM?`test`;

MySQL的空值和NULL有什么區別?(附示例)

1?SELECT?COUNT(colB)?FROM?`test`;

MySQL的空值和NULL有什么區別?(附示例)

結論:使用 count 會過濾掉 NULL 值,但是不會過濾掉空值。

總結

1、空值不占空間,NULL值占空間(占用一個字節)。

2、當字段不為NULL時,也可以插入空值。

3、當使用 IS NOT NULL 或者 IS NULL 時,只能查出字段中沒有不為NULL的或者為 NULL 的,不能查出空值。

4、使用 查詢時,會篩選掉空值和NULL值。

5、使用 count 統計時會過濾掉 NULL 值,但是不會過濾掉空值。

? 版權聲明
THE END
喜歡就支持一下吧
點贊11 分享