select * from xxxx where null<=>null;
-- null<=>null always return true,it's equal to "where 1=1".NULL 代表一个不确定的值,就算是两个 NULL,它俩也不一定相等
-- 任何有返回值的表达式中有NULL参与时,都会得到另外一个NULL值
-- 使用count(*) 或者 count(有null值的column)结果不同,count(有null值的column)<=count(*),不会统计null值得列。
-- MySQL 中支持在含有NULL值的列上使用索引,但是Oracle不支持.这就是我们平时所说的如果列上含有NULL那么将会使索引失效.
-- NULL值并是占用原有的字段空间存储,而是额外申请一个字节去标注,这个字段添加了NULL约束.(就像额外的标志位一样)
-- 推荐使用NOT NULL消除默认设置,使用0或者''空字符串来代替NULL。
select ifnull(null,'First is null'),ifnull(null+10,'First is null'),ifnull(concat('abc',null),'First is null');
-- 结果都是:First is null
select null=null ;
-- 结果:0
select null<=>null ;
-- 结果: 1
select count(*),count(有null值得列) from xxxx ;
-- 结果:count(*)统计所有,count(有null值得列)不会统计null值得行
select ifnull(null+10,'First is null') from xxxx where 有null值得列 is null ;
-- 结果: First is null
select ifnull(false,'First is null');
-- 结果: First is null
mysql null column
最新推荐文章于 2024-06-22 19:36:08 发布