MySQL燕十八老师课程笔记:第十二课:NULL

建表时,列后面的 not null default ‘’/ default 0 就是让这个列值不为 NULL,如果某个列确实没填值,也有默认值,不会为NULL。

为什么不想要NULL的值?
例:

create table test(
name varchar(20)
)engine myisam charset utf8;

insert into values
('lisi'),('wangwu'),('null');

问:这个插入的null,是不是真的null?
答:不是,这只是一个字符串。

insert into test values (NULL);
# 这个才是真的NULL
# 查询出用户名不为null的行:
select * from teset where name != null;
# 但是返回结果显示 empty set,那么,为什么 lisi 和 wangwu 没查出来呢?

原因:比较时,lisi = null 为假,取不出来;wangwu = null 为假,也取不出来。
在这里插入图片描述
原因: null 是空,因此 null 的比较需要用特殊的运算符:is null / is not null

select * from test where name is not null;
# 这次可以取出 lisi 和 wangwu。

回到最初的问题:
为什么不想要null的值?
答:不好比较,null是一种类型,比较时,只能用专门的 is null 和 is not null 来比较,碰到运算符,一律返回 null ;且效率不高,影响提高索引效果。
因此,我们往往在建表时,需要用 not null default ‘’ \0

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值