MySQL推断字段可否为null
我字段类型是not null,为何我可以插入空值
为毛not null的效率比null高
推断字段不为空的时候,到底要 select * from table where column <> '' 还是要用 select * from table wherecolumn is not null 呢。
带着上面几个疑难,我们来深入研究一下null 和 not null 到底有什么不同。
第一,我们要搞分明“空值” 和 “NULL” 的概念:
空值是不占用空间的
mysql中的NULL其实是占用空间的,下面是来自于MYSQL官方的解释:
“NULL columns require additional space in the row to record whether their values are NULL. For MyISAM tables, each NULL column takes one bit extra, rounded up to the nearest byte.”
打个比如来说,你有一个杯子,空值代表杯子是真空的,NULL代表杯子中装满了空气,虽然杯子看起来都是空的,但是区别是很大的。
搞分明“空值”和“NULL”的概念之后,题目根本就明了了,我们搞个例子测试一下:
CREATE TABLE `test` ( `col1` VARCHAR( 10 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL , `col2` VARCHAR( 10 ) CHARACTER SET utf8 COLLATE utf8_general_ci NULL ) ENGINE = MYISAM ;
插入数据:
INSERT INTO `test` VALUES (null,1);
mysql产生差错:
#1048 - Column 'col1' cannot be null
再来一条
INSERT INTO `test` VALUES ('',1);
成功插入。
可见,NOT NULL 的字段是不克不及插入“NULL”的,只能插入“空值”,上面的题目也就有答案了。
关于题目,上面我们已经说过了,NULL 其实并不是空值,而是要占用空间,所以mysql在进行比拼的时候,NULL 会参与字段比拼,所以对效率有一局部影响。
并且B树索引时不会存储NULL值的,所以要是索引的字段可认为NULL,索引的效率会下落许多。
MYSQL倡议列属性尽量为NOT NULL
长度验证:注意空值的''之间是没有空格的。
mysql> select length(''),length(null),length(' '); +------------+--------------+--------------+ | length('') | length(null) | length(' ') | +------------+--------------+--------------+ | 0 | NULL | 2 | +------------+--------------+--------------+
注意事项:
在进行count()统计某列的记载数的时候,要是采纳的NULL值,系统会主动忽略掉,但是空值是会进行统计到其中的。
推断NULL 用IS NULL 或者 IS NOT NULL, SQL语句函数中可以运用ifnull()函数来进行处置,推断空字符用=''或者 <>''来进行处理
关于MySQL特别的注意事项,关于timestamp数据类型,要是往这个数据类型插入的列插入NULL值,则涌现的值是目前系统工夫。插入空值,则会涌现 0000-00-00 00:00:00
关于空值的推断到底是运用is null 还是='' 要依据现实业务来进行区分。
以上就是MySQL推断字段可否为null的细致内容,更多请关注 百分百源码网 其它相干文章!