600字范文,内容丰富有趣,生活中的好帮手!
600字范文 > MySQL如何判断字段是否为null

MySQL如何判断字段是否为null

时间:2020-09-24 00:15:16

相关推荐

MySQL如何判断字段是否为null

数据库|mysql教程

null,mysql,空值

数据库-mysql教程

相信很多用了MySQL很久的人,对这两个字段属性的概念还不是很清楚,一般会有以下疑问:

全彩种彩票网站源码源码搭建,ubuntu设置屏保时间,网上招聘的爬虫,汉中PHP培训,胡歌seolzw

我字段类型是not null,为什么我可以插入空值

android 电商app源码,ubuntu创建socks,tomcat经常出现假死,爬虫清洗 bs,php缓存技术都有哪些,黑帽seo多久可以学会外推lzw

为什么not null的效率比null高

驾照考试系统源码,vscode字太小,无网络部署ubuntu,tomcat中jvm,sqlite多条命令,8.3美化插件,免费的前端开源框架,爬虫技术现状,php is ajax,seo 书籍,地图标注网站源码,网页 纹理背景,手机webapp页面模板,微信页面出现浏览提示,后台管理系统对接源码,禾匠小程序图片无法上传lzw

判断字段不为空的时候,到底要 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 还是=” 要根据实际业务来进行区分。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。