PHP群:95885625 Hbuilder+MUI群:81989597 站长QQ:634381967
    您现在的位置: 首页 > 数据库 > MySQL教程 > 正文

    mysql 空值(null)和空字符('')的区别是什么?

    作者:admin来源:网络浏览:时间:2020-10-06 10:37:54我要评论
    导读:日常开发中,一般都会涉及到数据库增删改查,那么不可避免会遇到Mysql中的NULL和空字符。空字符('')和空值(null)表面上看都是...
    日常开发中,一般都会涉及到数据库增删改查,那么不可避免会遇到Mysql中的NULL和空字符。
    空字符('')和空值(null)表面上看都是空,其实存在一些差异:

    定义:
    空值(NULL)的长度是NULL,不确定占用了多少存储空间,但是占用存储空间的
    空字符串('')的长度是0,是不占用空间的
    通俗的讲:
    空字符串('')就像是一个真空转态杯子,什么都没有。
    空值(NULL)就像是一个装满空气的杯子,含有东西。
    二者虽然看起来都是空的、透明的,但是有着本质的区别。

    区别:
    在进行count()统计某列时候,如果用null值系统会自动忽略掉,但是空字符会进行统计。
    不过count(*)会被优化,直接返回总行数,包括null值。
    判断null用is null或is not null,SQL可以使用ifnull()函数进行处理;判断空字符用=''或者!=''进行处理。
    对于timestamp数据类型,插入null值会是当前系统时间;插入空字符,则出现0000-00-00 00:00:00

    总结:
    所以在设置默认值的时候,尽量不要用null当默认值,如果字段是int类型,默认为0;如果是varchar类型,默认值用空字符串('')会更好一些。带有null的默认值还是可以走索引的,只是会影响效率。当然,如果确认该字段不会用到索引的话,也是可以设置为null的。

    在设置字段的时候,可以给字段设置为 not null ,因为 not null 这个概念和默认值是不冲突的。我们在设置默认值为('')的时候,虽然避免了null的情况,但是可能存在直接给字段赋值为null,这样数据库中还是会出现null的情况,所以强烈建议都给字段加上 not null。
    转载请注明(B5教程网)原文链接:https://b5.mxunkeji.com/content-35-6344-1.html
    相关热词搜索: mysql