百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>数据库> MySQL推断字段可否为null
分享文章到:

MySQL推断字段可否为null

发布时间:08/01 来源:未知 浏览: 关键词:
推断字段可否为空(null)时候,可以用select*fromtablewherecolumnisnotnull下令,含义是从数据库表中寻出不是为空值的所有列表。 信赖许多用了MySQL很久的人,对这两个字段属性的概念还不是很分明,个别会有下列疑难:

我字段类型是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的细致内容,更多请关注 百分百源码网 其它相干文章!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有151人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板