主页 > MySQL教程 > 正文

mysql探求之null与not null

信任许多用了mysql好久的人,对这两个字段特点的概念还不是很清楚,一般会有以下疑问:

1、我字段类型是not null,为什么我能够刺进空值

2、为毛not null的功率比null高

3、判别字段不为空的时分,究竟要  select * from table where column <> '' 仍是要用 select * from table where column is not null 呢。

带着上面几个疑问,咱们来深化研究一下null 和 not null 究竟有什么不一样。

首要,咱们要搞清楚“空值” 和 “NULL” 的概念:

1、空值是不占用空间的

2、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”的,只能刺进“空值”,上面的问题1也就有答案了。

关于问题2,上面咱们现已说过了,NULL 其实并不是空值,而是要占用空间,所以mysql在进行比较的时分,NULL 会参加字段比较,所以对功率有一部分影响。

并且B树索引时不会存储NULL值的,所以假如索引的字段能够为NULL,索引的功率会下降许多。

咱们再向test的表中刺进几条数据:

INSERT INTO `test` VALUES ('', NULL);  
INSERT INTO `test` VALUES ('1', '2');

现在表中数据:

现在依据需求,我要计算test表中col1不为空的一切数据,我是该用“<> ''” 仍是 “IS NOT NULL” 呢,让咱们来看一下成果的差异。

SELECT * FROM `test` WHERE col1 IS NOT NULL

SELECT * FROM `test` WHERE col1 <> ''

能够看到,成果截然不同,所以咱们必定要依据事务需求,搞清楚究竟是要用那种查找条件。


上一篇:MySQL Hash索引和B-Tree索引的差异
下一篇: Mysql中 int(10)和int(11)的差异

PythonTab微信大众号:

Python技能交流合作群 ( 请勿加多个群 ):

群1: 87464755

群2: 333646237

群3: 318130924

群4: 385100854