前言:
谈起这个话题,是因为想整理一个开发规范,中间涉及到一条,建表的时候建议字段定义为NOT NULL,但是为什么不可以是NULL呢?怎么让开发相信NOT NULL一定比NULL好呢,往下看把
1、NULL 和 ‘’ 值有什么区别?
NULL值会占一个到两个字节的空间,而‘’值是不会占用空间的。
https://dev.mysql.com/doc/refman/5.7/en/innodb-physical-record.html
2、为什么字段类型是 NOT NULL 可以插入 ‘’ 值呢?
看看官方给的例子和解释吧,感觉这个解释很完美
3、如何判断字段为 NULL 和 ‘’ ?
4、为什么索引中 ‘’ 比 NULL 效率高呢?
下面来看一个例子:因为B树索引是不会存储NULL值的,索引字段可以NULL,索引效率会下降很多
root@localhost:mysql.sock 15:03:25 [tom]>show create table a;