MySql中判断null可以用 is null 和 =
创新互联公司是一家以重庆网站建设公司、网页设计、品牌设计、软件运维、seo优化、小程序App开发等移动开发为一体互联网公司。已累计为生料搅拌车等众行业中小客户提供优质的互联网建站和软件开发服务。
1、is null :仅仅可以判断null值,可读性较高,建议使用。
select * from base_user where username is null
2、= :既可以判断null值,也可以判断普通的数值,可读性较低。
select * from base_user where username = null
查询字段为空的数据。如下三条语句查询的结果各不相同。
select count(0) from tps_uw_detail where trim(coreContNo)=''; ###1736
select count(0) from tps_uw_detail where coreContNo is null; ###735
select count(0) from tps_uw_detail where (coreContNo is null or trim(coreContNo)='');##2471
='';就是存的空字符串;is null 就是默认的。
由于是后来新加的字段,默认为null,所以历史数据都为null。表中加上这个字段后,再落库的数据就是空字符串了。
根据自己的需求选用脚本,第三个是适合我的。
判断方法: if ISNULL(aBegBalRule) || LENGTH(trim(aBegBalRule))1 THEN ELSE END IF; NULL值可能令人感到奇怪直到你习惯它。概念上,NULL意味着“没有值”或“未知值”,且它被看作与众不同的值。为了测试NULL,你不能使用算术比较 操作符例如=、或!=。为了说明它,试试下列查询: mysql SELECT 1 = NULL, 1 NULL, 1 NULL, 1 NULL; +----------+-----------+----------+----------+ | 1 = NULL | 1 NULL | 1 NULL | 1 NULL | +----------+-----------+----------+----------+ 返回信鸽网顶部| NULL | NULL | NULL | NULL | +----------+-----------+----------+----------+ 很显然你不能通过这些比较得到有意义的结果。相反使用IS NULL和IS NOT NULL操作符: mysql SELECT 1 IS NULL, 1 IS NOT NULL; +-----------+---------------+ | 1 IS NULL | 1 IS NOT NULL | +-----------+---------------+ | 0 | 1 | +-----------+---------------+ 请注意在MySQL中,0或 NULL意味着假而其它值意味着真。布尔运算的默认真值是1。 返回信鸽网顶部对NULL的特殊处理即是在前面的章节中,为了决定哪个动物不再是活着的,使用death IS NOT NULL而不使用death != NULL的原因。 在GROUP BY中,两个NULL值视为相同。 执行ORDER BY时,如果运行 ORDER BY ... ASC,则NULL值出现在最前面,若运行ORDER BY ... DESC,则NULL值出现在最后面。 NULL操作的常见错误是不能在定义为NOT NULL的列内插入0或空字符串,但事实并非如此。在NULL表示"没有数值"的地方有数值。
在讲null之前,我们先看一个例子
表数据如下:
然后我们想查出所有名字不为'chen'的其它行记录,我们有可能这样写:
但是结果好像不太如我们所愿,id为1的那条记录没有被查出来,null肯定和'chen'不相等呀,为什么会查不出呢?
NUll值对于新手来说非常容易混淆,经常会被认为null与空字符串''是一样的,但事实上,这两者是非常不一样,NULL表示的是“a missing unknown value”,而字符串''是一个确定的值,这本质上就已经不一样了。
举个例子:
第一条insert语句认为这个手机号还不确定是多少,是a missing unknown phone number
第二条代表这个手机号码是确定的,它的手机号码为空字符串
为了处理和null相关的比较,在mysql中可以用is null、is not null、=、isnull()来测试比较,不能用如=、、来和null值比较测试,任何值(包括和null本身)与null对比和函数运算操作结果都为null
如下三个例子可以说明问题:
但是呢,凡事都有个例外:
当用distinct、group by、order by时,此时不同的null值被视为相等计算。
最重要的是,在mysql中,0和null代表假,其它的任何值都代表真
所以回头看最开始的例子,当我们的where条件为name!='chen'时,它与id=1的行进行比较,即测试:
'chen'!='chen'
这个测试结果为0,为假,所以id=1这一行就不会被查出来。接下来再测试:
'zhang'!='chen'
这个测试结果为1,为真,所以id=2这一行就可以被查出来。接下来再测试:
NULL!='chen'
这个测试结果为NULL,为假,所以id=3这一行就不会被查出来。
所以最终的结果就只有id=2这一行的数据被查出来了。
那如果要达到我们的目地怎么办?
推荐用第一种方法。
因为mysql对了null列的查找是有查询优化的:
而第二种在列上加上函数的查询时索引是不起作用的。
其它注意事项
select * from tableName where fieldName is null ;
---tableName 是你的查询的表名
---fieldName 是你要查询的字段名
请阅读,并采纳!
null表示的含义是未知,即不知道有没有。 和‘’空字符串不等,因为空字符串相当于没有值。 null代表的是不知道有没有值。 所以在数据查询中如果字段默认值是null,想查询出不等于某个条件的一定要加上——字段名 is null 或者字段名 is not null来...