MySQL中空值Null和空字符‘‘的具体使用

 更新时间:2022年05月25日 15:02:25   作者:桐花思雨  
本文主要介绍了MySQL中空值Null和空字符''的具体使用,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

1. 空值 Null 和空字符 ''

日常开发中,一般都会涉及到数据库增删改查,那么不可避免会遇到 MySQL 中的 NULL 和空字符 '',二者表面上看都是空,其实存在一些差异的

  • 空值 NULL 的长度是 NULL,不确定占用了多少存储空间,它是占用存储空间的
  • 空字符串 '' 的长度是 0,是不占用空间的*

通俗的讲:空字符串 '' 就像是一个真空状态的杯子,什么都没有;而空值 NULL 就像是一个装满空气的杯子,是有东西的。二者虽然看起来都是空的、透明的,但是有着本质的区别

2. 空值 Null 和空字符 '' 在查询方式上的对比

2.1. 创建 SQL 脚本

CREATE TABLE `test_1` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `username` varchar(255) DEFAULT NULL,
  `password` varchar(255) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8mb4;

--插入数据
INSERT INTO test_1 VALUES(1,'李斯','111111');
INSERT INTO test_1 VALUES(2,'','');
INSERT INTO test_1 VALUES(3,null,'');
INSERT INTO test_1 VALUES(4,null,1);

表中的数据如下,注意 null 值与 ''

在这里插入图片描述

2.2. 查询 username 列为空字符串 '' 的所有数据

在这里插入图片描述

2.3. 查询 username 列为空值 null 的所有数据

2.3.1. 错误 SQL

在这里插入图片描述

2.3.2. 正确 SQL

在这里插入图片描述

2.4. 查询 username 列不为空值 null 的所有数据

2.4.1. 错误 SQL

在这里插入图片描述

2.4.2. 正确 SQL

在这里插入图片描述

  • 比较字符 =,>,< ,<>!= 都不能用于查询比较 null 值,如果需要查询空值 null,必须使用 is nullis not null
  • 空值 '' 可以使用 =, !=, <, > 等算术运算符来查询的

3. 空值 Null 和空字符 '' 在 count() 函数查询的对比

3.1. 查询 username 列数据总数

在这里插入图片描述

使用 count() 的时候,空值 null 并不会被当成有效值去统计的

空字符串 '' 是会被 count() 函数所统计的

4. MySQL 中的比较运算符

运算符含义
=等于
<=>安全等于,可以比较 null
<> 或 !=不等于
>=大于等于
<=小于等于
>大于
<小于
IS NULL判断一个值是否为 null
IS NOT NULL判断一个值是否不为 null

到此这篇关于MySQL中空值Null和空字符‘‘的具体使用的文章就介绍到这了,更多相关MySQL 空值Null和空字符‘‘内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySql中怎样查询表是否被锁

    MySql中怎样查询表是否被锁

    这篇文章主要介绍了MySql中怎样查询表是否被锁问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07
  • 详解MySQL8.0原子DDL语法

    详解MySQL8.0原子DDL语法

    这篇文章主要介绍了详解MySQL8.0原子DDL语法的相关资料,帮助大家更好的理解和学习使用MySQL,感兴趣的朋友可以了解下
    2021-03-03
  • Mysql 日期格式化及复杂日期区间查询

    Mysql 日期格式化及复杂日期区间查询

    最近在做项目涉及到Mysql的复杂日期查询,日期查询其实在数据库中查询其实还是用的挺多的,所以本文就来详细的介绍一下,感兴趣的可以了解一下
    2021-09-09
  • MariaDB(Mysql分支)my.cnf配置文件中文注释版

    MariaDB(Mysql分支)my.cnf配置文件中文注释版

    这篇文章主要介绍了MariaDB my.cnf配置文件中文注释版,MariaDB是Mysql的一个分支,完全兼容Mysql,需要的朋友可以参考下
    2014-06-06
  • MySQL创建定时任务实例(每天凌晨1点、每小时、每分钟、某一时间点)

    MySQL创建定时任务实例(每天凌晨1点、每小时、每分钟、某一时间点)

    在mysql中有时候要定时更新或者删除一部分数据需要用到mysql的定时任务,下面这篇文章主要给大家介绍了关于MySQL创建定时任务的相关资料,包括每天凌晨1点、每小时、每分钟、某一时间点等,需要的朋友可以参考下
    2023-03-03
  • 优化mysql数据库的经验总结

    优化mysql数据库的经验总结

    本篇文章是对优化mysql数据库的经验进行了详细的总结介绍,需要的朋友参考下
    2013-06-06
  • MySQL中的用户创建与权限管理

    MySQL中的用户创建与权限管理

    这篇文章主要介绍了MySQL中的用户创建与权限管理,文章通过围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-08-08
  • Mysql存储过程学习笔记--建立简单的存储过程

    Mysql存储过程学习笔记--建立简单的存储过程

    我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给定参数(如果该存储过程带有参数)来调用执行它。
    2014-08-08
  • MySQL如何快速导入数据

    MySQL如何快速导入数据

    这篇文章主要介绍了MySQL如何快速导入数据,帮助大家更好的理解和学习MySQL,感兴趣的朋友可以了解下
    2020-08-08
  • MySQL启用SSD存储的实例详解

    MySQL启用SSD存储的实例详解

    这篇文章主要介绍了MySQL启用SSD存储的实例详解的相关资料,希望通过本文能帮助到大家,需要的朋友可以参考下
    2017-10-10

最新评论