mysql null column

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值