MySQL的空值和NULL区别
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
MySQL的空值和NULL区别
从本质上区别:
1、空值不占空间
2、null值占空间
通俗的讲:
空值就像是⼀个真空转态杯⼦,什么都没有,⽽null值就是⼀个装满空⽓的杯⼦,虽然看起来都是⼀样的,但是有着本质的区别。
例⼦:
创建⼀个test表,colA是不可以存放null值的,colB是能存放null值的。
1 CREATE TABLE `test` (
2 `colA` varchar(255) NOT NULL,
3 `colB` varchar(255) DEFAULT NULL
4 ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
插⼊⼀个null值试试,会发⽣什么情况?
1 INSERT INTO `test`(`colA`, `colB`) VALUES (NULL, NULL);
//出现报错,原因是colA是不能插⼊null值。
那么如果两个字段同时插⼊空值,会怎么样。
1 INSERT INTO `test`(`colA`, `colB`) VALUES ('', '');
插⼊成功,说明字段即使设置为null值的时候,是可以插⼊空值的
---------------------------------------------------------------查询---------------------------------------------------------
现在表⾥有三条数据
接下来我们使⽤ is not null 和 <> 检索数据表⾥的数据
1、使⽤IS NOT NULL 的查询
1 SELECT * FROM `test` WHERE colA IS NOT NULL
1 SELECT * FROM `test` WHERE colB IS NOT NULL
结论:使⽤ IS NOT NULL 查询不会过滤空值,但是会过滤掉NULL。
2、使⽤ <> 的查询
1 SELECT * FROM `test` WHERE colA <> '';
1 SELECT * FROM `test` WHERE colA <> '';
结论:使⽤ <> 会过滤掉NULL和空值。
3、使⽤ count 查询
1 SELECT COUNT(colA) FROM `test`;
1 SELECT COUNT(colB) FROM `test`;
结论:使⽤ count 会过滤掉 NULL 值,但是不会过滤掉空值。
总结
1、空值不占空间,NULL值占空间(占⽤⼀个字节)。
2、当字段不为NULL时,也可以插⼊空值。
3、当使⽤ IS NOT NULL 或者 IS NULL 时,只能查出字段中没有不为NULL的或者为 NULL 的,不能查出空值。
4、使⽤ <> 查询时,会筛选掉空值和NULL值。
5、使⽤ count 统计时会过滤掉 NULL 值,但是不会过滤掉空值。