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-10-01 12:47:02 发布
文章探讨了SQL中NULL值的特性,包括NULL不等于NULL,涉及比较操作和COUNT函数在包含NULL值时的行为。提到了MySQL和Oracle在NULL值索引上的区别,并建议使用NOTNULL约束和IFNULL函数来处理NULL。示例展示了如何在查询中处理NULL值。
摘要由CSDN通过智能技术生成