我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL系列关于NUll值的经验总结分析教程

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL系列关于NUll值的经验总结分析教程

1.测试数据


create table test_null (
    id int,
    name varchar(20),
    chinese int,
    math int,
    english int
) charset=utf8;

insert into test_null 
values
(1,null,80,70,68),
(2,'张三',60,null,null),
(3,'李四',null,90,80),
(4,'王五',90,60,75),
(5,null,null,50,95);

结果如下:

在这里插入图片描述

2.null值带给我们的不便影响

1)过滤有所不同,只能使用is null或者is not null;


# null值不能使用 == 或 != 来比较
# 下面两种用法都是错误的
select *
from test_null
where name == null;

select *
from test_null
where name != null;

# null值一般使用 is null 或 is not null 来比较
# 下面两种用法才是正确的
select *
from test_null
where name is null;

select *
from test_null
where name is not null;

2)出现null值,会导致+ - * /运算失效;


select 	
	*,(chinese+math+english) as 总分
from test_null;

结果如下:

在这里插入图片描述

3)null值对聚合函数无影响,聚合函数会直接忽略null值;


select 
    sum(chinese) 语文总分,
    sum(math) 数学总分,
    sum(english) 外语总分
from test_null

结果如下:

在这里插入图片描述

3.空格、空值和null,我们应该怎么判断呢?

1)空格、空值和null的区别

用一个形象的比喻来说明这三者的区别。首先空格很好理解,一个空字符串吗,占据一定的空间大小。不好理解的其实是空值和null,空值相当于一个杯子是真空状态的,什么也没有,null表示的杯子中有空气。

MySQL中,null是未知的,且占用空间的。null使得索引、索引统计和值都更加复杂,并且影响优化器的判断。空值('')是不占用空间的,注意空值的''之间是没有空格的。在进行count()统计某一列记录数的时候,如果存在null值,会被系统自动忽略掉,但是空值会被统计到其中。判断null使用的是is nullis not null,但判断空字符使用的是= ,!=, <>来进行处理。对于timestamp数据类型,如果插入null值,则出现的值是当前系统时间。插入空值,则会出现0000-00-00 00:00:00。对于已经创建好的表,普通的列将null修改为not null带来的性能提升较小,所以调优时候没有比要注意。

2)出现了null值,我应该怎么办?

通过上面的分析我们已经知道了,当表中存在null值,会导致加、减、乘、除运算失效。那么我们怎么处理这些null值比较好呢?

第一种方式:直接使用is not null将这些null值过滤掉,但是这样会将其它非缺失值的字段过滤掉,造成数据的浪费。

第二种方式:也是我们推荐的方式,我们使用函数进行缺失值的填充。

ifnull()和coalesce()函数的使用:


select 
    	id,
    	coalesce(name,'无名氏') name,
    	coalesce(chinese,0) chinese,
    	ifnull(math,0) math,
    	ifnull(english,0) english
from test_null;

结果如下:

在这里插入图片描述

以上就是MySQL系列关于NUll值的经验总结分析的详细内容,更多关于MySQL中的NUll值的资料请关注编程网其它相关文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL系列关于NUll值的经验总结分析教程

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

基于MongoDB的日志分析与监控系统搭建经验总结

一、需求分析与系统设计随着互联网和移动设备的普及,各类网络应用和系统的日志数量急剧增长。对这些海量的日志进行分析和监控可以帮助企业实时了解系统运行情况,发现潜在的问题并进行及时修复,提高系统的稳定性和可靠性。为了满足这一需求,我们团队基于M
基于MongoDB的日志分析与监控系统搭建经验总结
2023-11-04

基于MongoDB的实时日志分析与报警系统搭建经验总结

在当今信息时代,日志分析与报警系统对于企业的数据管理和安全至关重要。随着云计算和大数据的兴起,传统的关系型数据库已经无法满足日益增长的数据量和实时性需求。在这样的背景下,NoSQL数据库成为了一种备受关注的选择。本文将分享基于MongoDB
基于MongoDB的实时日志分析与报警系统搭建经验总结
2023-11-02

基于MongoDB的实时日志分析与可视化系统搭建经验总结

基于MongoDB的实时日志分析与可视化系统搭建经验总结引言:随着互联网的迅猛发展,各个企业面临着大数据处理和分析的挑战。日志分析是企业运营和安全管理的重要组成部分,搭建一个高效的日志分析与可视化系统对企业决策和问题排查非常关键。本文将总结
基于MongoDB的实时日志分析与可视化系统搭建经验总结
2023-11-03

基于MongoDB的实时日志分析与异常检测系统搭建经验总结

随着互联网和移动设备的普及,日志数据的产生量也在不断增加,如何高效地对日志数据进行分析和检测异常成为了一个非常重要的问题。本文将介绍如何基于MongoDB搭建一个实时日志分析和异常检测系统,并分享一些经验总结。一、MongoDB简介Mong
基于MongoDB的实时日志分析与异常检测系统搭建经验总结
2023-11-03

编程热搜

目录