mysql null 0 空,MySQL的空值和NULL区别
從本質(zhì)上區(qū)別:
1、空值不占空間
2、null值占空間
通俗的講:
空值就像是一個(gè)真空轉(zhuǎn)態(tài)杯子,什么都沒有,而null值就是一個(gè)裝滿空氣的杯子,雖然看起來都是一樣的,但是有著本質(zhì)的區(qū)別。
例子:
創(chuàng)建一個(gè)test表,colA是不可以存放null值的,colB是能存放null值的。
1 CREATE TABLE `test` (2 `colA` varchar(255) NOT NULL,3 `colB` varchar(255) DEFAULT NULL4 ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
插入一個(gè)null值試試,會(huì)發(fā)生什么情況?
1 INSERT INTO `test`(`colA`, `colB`) VALUES (NULL, NULL);
//出現(xiàn)報(bào)錯(cuò),原因是colA是不能插入null值。
那么如果兩個(gè)字段同時(shí)插入空值,會(huì)怎么樣。
1 INSERT INTO `test`(`colA`, `colB`) VALUES ('', '');
插入成功,說明字段即使設(shè)置為null值的時(shí)候,是可以插入空值的
---------------------------------------------------------------查詢---------------------------------------------------------
現(xiàn)在表里有三條數(shù)據(jù)
接下來我們使用 is not null 和 <> 檢索數(shù)據(jù)表里的數(shù)據(jù)
1、使用IS NOT NULL 的查詢
1 SELECT * FROM `test` WHERE colA IS NOT NULL
1 SELECT * FROM `test` WHERE colB IS NOT NULL
結(jié)論:
使用 IS NOT NULL 查詢不會(huì)過濾空值,但是會(huì)過濾掉NULL。
2、使用 <> 的查詢
1 SELECT * FROM `test` WHERE colA <> '';
1 SELECT * FROM `test` WHERE colA <> '';
結(jié)論:
使用 <> 會(huì)過濾掉NULL和空值。
3、使用 count 查詢
1 SELECT COUNT(colA) FROM `test`;
1 SELECT COUNT(colB) FROM `test`;
結(jié)論:
使用 count 會(huì)過濾掉 NULL 值,但是不會(huì)過濾掉空值。
總結(jié)
1、空值不占空間,NULL值占空間(占用一個(gè)字節(jié))。
2、當(dāng)字段不為NULL時(shí),也可以插入空值。
3、當(dāng)使用 IS NOT NULL 或者 IS NULL 時(shí),只能查出字段中沒有不為NULL的或者為 NULL 的,不能查出空值。
4、使用 <> 查詢時(shí),會(huì)篩選掉空值和NULL值。
5、使用 count 統(tǒng)計(jì)時(shí)會(huì)過濾掉 NULL 值,但是不會(huì)過濾掉空值。
總結(jié)
以上是生活随笔為你收集整理的mysql null 0 空,MySQL的空值和NULL区别的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java判_java中判空
- 下一篇: 整合php和mysql lnmp,安装配