MySQL判断空值的三种方法

 更新时间:2024年03月11日 11:40:49   作者:积极向上的ACC  
在创建表时,可以指定的列是否可以不包含值,如果在一个列不包含值,则其称其为空值NULL,NULL一个特殊值,代表缺失的值或者不适用的情况,表示未知数据,本文给大家介绍了MySQL判断空值的三种方法,需要的朋友可以参考下

在开始前我们先来做一个思考,如下图:

根据上图箭头所指的位置,我们该如何分别去判断空?表从上到下依次为:t_user,t_user_1,t_user_2,下面分三种情况去聊聊。

1. is null

命令行查t_user表

从命令行可以看出第五条数据存在空值,那么我们执行如下语句试试:

select * from t_user where id='NULL'

运行结果:

可以看到并没有查出数据,这里存在一个可视化的问题,就是在命令行显示的空值和在可视化工具显示会有偏差,我们转去可视化工具查看:

这里就容易出现问题了,为了更清楚看到数据,我们可以导出表数据(字段id的数据类型tinytext):

可以看到箭头指向的值是NULL,并不是'NULL',这就是空值和字符的区别,所以我们上面执行的语句显然查不出。

SQL中有判断空值的关键字,那就是is null,我们执行如下语句:

select * from t_user where id is null

执行结果:

2. =''

先查下表t_user_1:  

可以看到最后一行是空白的,我们再导出sql看下语句:  

也是空的字符,由此可以用=''作为关键字来查询

select * from t_user_1 where id =''

执行结果:

3. ='NULL'

先查下表t_user_2:

查出来的结果和第一点一致,那也是一样的语句吗?前面提到过命令行和可视化工具会有偏差,那么我们导出语句对比一下:

可以看出上面的是空值,而下面的是字符NULL,不要混淆两者。对于字符的NULL,可以用='NULL'='null'关键字查询:

select * from t_user_2 where id='NULL'

select * from t_user_2 where id='null'

到此这篇关于MySQL判断空值的三种方法的文章就介绍到这了,更多相关MySQL判断空值内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • redhat7通过yum安装mysql5.7.17教程

    redhat7通过yum安装mysql5.7.17教程

    这篇文章主要为大家详细介绍了redhat7通过yum安装mysql5.7.17教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-01-01
  • 超详细mysql left join,right join,inner join用法分析

    超详细mysql left join,right join,inner join用法分析

    比较详细的mysql的几种连接功能分析,只要你看完就能学会的好东西
    2008-08-08
  • Mysql数据库分库和分表方式(常用)

    Mysql数据库分库和分表方式(常用)

    本文主要给大家介绍Mysql数据库分库和分表方式(常用),涉及到mysql数据库相关知识,对mysql数据库分库分表相关知识感兴趣的朋友一起学习吧
    2016-03-03
  • 分享MYSQL插入数据时忽略重复数据的方法

    分享MYSQL插入数据时忽略重复数据的方法

    当程序中insert时,已存在的数据不插入,不存在的数据insert。在网上搜了下,可以使用存储过程或者是用NOT EXISTS 来判断是否存在
    2013-09-09
  • MySql 查询符合条件的最新数据行

    MySql 查询符合条件的最新数据行

    这篇文章主要介绍了MySql 怎么查出符合条件的最新的数据行,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-07-07
  • MySQL给查询记录增加序列号的实现方法

    MySQL给查询记录增加序列号的实现方法

    这篇文章主要介绍了MySQL给查询记录增加序列号的实现方法,文中通过代码示例讲解的非常详细,对大家的学习或工作有一定的参考价值,需要的朋友可以参考下
    2023-11-11
  • MySQL Join算法原理解析

    MySQL Join算法原理解析

    本文详细介绍了MySQL中常见的四种JOIN算法:嵌套循环连接(NLJ)、索引嵌套循环连接(INLJ)、块嵌套循环连接(BNLJ)和基于哈希的连接(HashJoin),每种算法都有其适用场景和性能特点,感兴趣的朋友一起看看吧
    2025-02-02
  • MySQL使用show status查看MySQL服务器状态信息

    MySQL使用show status查看MySQL服务器状态信息

    这篇文章主要介绍了MySQL使用show status查看MySQL服务器状态信息,需要的朋友可以参考下
    2017-01-01
  • macOS Sierra安装Apache2.4+PHP7.0+MySQL5.7.16

    macOS Sierra安装Apache2.4+PHP7.0+MySQL5.7.16

    这篇文章主要为大家详细介绍了macOS Sierra安装Apache2.4+PHP7.0+MySQL5.7.16的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-01-01
  • MySQL 权限控制详解

    MySQL 权限控制详解

    这篇文章主要介绍了MySQL 权限控制详解的相关资料,帮助大家更好的理解和学习使用MySQL,感兴趣的朋友可以了解下
    2021-03-03

最新评论