面试题:对NotNull字段插入Null值 有啥现象?
Hi,大家好!我是白日梦。
今天我要跟你分享的话题是:“对NotNull字段插入Null值有啥现象?”
一、 推荐阅读
首发地址:https://mp.weixin.qq.com/s/b30fKiQJTZARZazQdv6WKw
使用推荐阅读,有更好的阅读体验,公众号首发!分享不易,欢迎关注~
二、从一个实验开始
首先创建数据表

id为not null类型,我们像下面这样插入。

所以说默认情况下,如果该列要求不能为null。用户还往里面写入null,就会报错:cannot be null
当然本篇文章并没有结束,下面跟大家分享另外一个拓展知识:sql mode 。
这个拓展知识点也是下一篇文章“ 能谈谈 date、datetime、time、timestamp、year的区别吗?” 的储备知识。
三、sql 的执行模式
这就引出了一个 sql_mode 的概念,也就是SQL的执行模式。
默认情况下MySQL会用严格模式运行SQL。
你可以像下面这样查看MySQL使用了哪些sql mode。

MySQL会根据
sql_mode系统变量的值将这些模式不同地应用于不同的客户端。使用不同的sql mode执行sql,可能会得到不同的响应结果。
四、做几个小实验
为了更直观的看出sql mode 对sql执行结果的影响,推荐你看一下下面的这两个小Demo,都不复杂。
Demo1:
创建一张简单的表 t3,id非空、没有默认值。

先看看默认的情况下,会有什么响应!
在默认的sql mode下,执行一条插入空值的语句,发现报错了

再看看,关闭严格的sql mode后会有什么响应。
关闭严格模式后执行的结果如下图所示。
你会发现这次结果是 wanring + MySQL帮你插入默认值

Demo2:
默认开启严格模式后往int类型的列插入空串(任意串)会报错。
关闭严格模式后,执行下面的SQL会爆出wanrning。

查看插入的结果

从上面的实验来看,相信你已经看出了:无论是否开启了严格模式,MySQL都不允许往not null字段插入null值,它不会因为你插入null,而将null转成该数据类型的0值。
所谓都严格模式,就是将参数 NO_AUTO_CREATE_USER 设置给sql mode
五、需要你了解的几个 sql mode
下面再为大家介绍几个和日期相关的sql mode。
研发的同学了解就好了,不用刻意记住它,了解就是加分项!
1、STRICT_TRANS_TABLES:
将其加入到sql_mode之后,MySQL会判断是否可以直接把用户给的值插入事务表中,如果不能就中止该语句。对于非事务表,如果该值出现在单行语句或多行语句的第一行中,则中止该语句。
结合上面的例子可以更好的理解STRICT_TRANS_TABLES的作用。
2、NO_ZERO_IN_DATE
将其加入到sql_model之后,MySQL将不允许你将诸如 0000-10-10、2020-00-10、2020-10-00等年份、月份、日期为零的值插入到Date列中。
目前该参数处于目前该参数默认会生效,但是在未来的版本中将会被删除。
3、NO_ZERO_DATE:
该参数控制MySQL是否允许将 '0000-00-00'作为有效日期。
- 如果未启用此模式,
'0000-00-00'允许插入不会产生警告。 - 如果启用此模式,
'0000-00-00'允许插入且产生警告。 - 如果启用了此模式和严格模式,
'0000-00-00'插入产生错误,除非IGNORE同样给出。对于INSERT IGNORE和UPDATE IGNORE,'0000-00-00'允许插入且产生警告。
参考:
https://dev.mysql.com/doc/refman/5.7/en/sql-mode.html
六、结语
下一篇文章白日梦将结合本节的 sql mode 同你分享另一个话题:
“能谈谈 date、datetime、time、timestamp、year的区别吗?”
为大家带来MySQL面试专题!本文是第 3 篇、全文110篇!公众号首发!
以问答的方式,由浅入深的帮你应对各类MySQL面试题的狂轰滥炸!当然也不乏会分享一些高阶读写分离数据库中间件原理及落地的技术实现,为你揭开数据库中间件神秘的面纱!
面试官都关注了!你还在犹豫什么呢?
查看MySQL专题110篇文章大纲:https://mp.weixin.qq.com/s/HTw-Z-SyprYA8bCBZ4NpGQ

面试题:对NotNull字段插入Null值 有啥现象?的更多相关文章
- mysql中,通过json_insert函数向json字段插入键值?json_insert函数的使用?
需求描述: 通过json_insert向json字段中插入值,在此进行实验,记录下. 操作过程: 1.查看已经有的包含json数据类型的表 mysql> select * from tab_js ...
- c# access插入null值
c# 插入access数据库 提示错误: Parameter @DeviceLocation has no default value. 参数@DeviceLocation 的有没有默认值. Stri ...
- mysql where 条件中的字段有NULL值时的sql语句写法
比如你有一个sql语句联表出来之后是这样的 id name phone status 1 张三 ...
- Mybatis 插入null值报错
解决方法: 1.在settings中配置 <setting name="jdbcTypeForNull" value="OTHER"/> MyBat ...
- jdbc 占位符插入null值 NullPointerException
如果变量flag 为空 ,那么executeUpdate 后面的参数 bookCollect.getFlag() 就会被executeUpdate()方法忽略掉,程序会报错. String addSq ...
- Ibatis insert语句插入null引发的错误
公司使用的orm框架为ibatis,其中默认的insert语句一直都是这样写的: <insert id="insert" parameterClass="activ ...
- MySQL NULL 值处理
MySQL NULL 值处理 我们已经知道MySQL使用 SQL SELECT 命令及 WHERE 子句来读取数据表中的数据,但是当提供的查询条件字段为 NULL 时,该命令可能就无法正常工作. 为了 ...
- FDQuery 怎么能插入NULL参数
[FireDAC][Phys][MSSQL]-335. Parameter [fieldAA] data type is unknown. Hint: specify TFDParam.DataTyp ...
- 吴裕雄 20-MySQL NULL 值处理
MySQL NULL 值处理我们已经知道 MySQL 使用 SQL SELECT 命令及 WHERE 子句来读取数据表中的数据,但是当提供的查询条件字段为 NULL 时,该命令可能就无法正常工作.为了 ...
随机推荐
- 用于编写下一代JavaScript的编译器。
下载 用于编写下一代JavaScript的编译器. 支持巴别塔 Babel(发音为babble)是一个由社区驱动的项目,被许多公司和项目使用,由一群志愿者维护.如果你愿意帮助支持这个项目的未来,请考虑 ...
- Oracle 按不同时间分组统计
1.按年 select to_char(record_date,'yyyy'), sum(col_8) as total_money from table_name where group by to ...
- shell-脚本的执行
1. shell脚本的执行 当shell脚本以非交互的方式运行时,它会先查找环境变量ENV,该变量指定了一个环境文件(通常是.bashrc),然后从该环境变量文件开始执行,当读取了ENV文件后,she ...
- dubbo使用问题
新入职此公司, 发现公司使用的框架原来是传说中的分布式的(原谅我以前在传统公司工作,并远离浪潮久矣), 使用过程中发现各服务之间使用 dubbo 进行通信. 特地总结下遇见的坑,为以后总结经验. ...
- OpenCV开发笔记(七十):红胖子带你傻瓜式编译VS2017x64版本的openCV4
前言 红胖子来也!!! opencv_contrib是opencv提供额外的工具,提供一些基础算法,之前编译了不带opencv_contrib的版本,不带opencv_contrib的cuda硬 ...
- 树状数组(BIT)—— 一篇就够了
树状数组(BIT)-- 一篇就够了 前言.内容梗概 本文旨在讲解: 树状数组的原理(起源,原理,模板代码与需要注意的一些知识点) 树状数组的优势,缺点,与比较(eg:线段树) 树状数组的经典例题及其技 ...
- day33 Pyhton logging 模块和包
一内容回顾 try/except try/except/else try/finally try/except try/except/finally try/except/else/finally 报 ...
- PHP7下的协程实现 转
前言 相信大家都听说过『协程』这个概念吧. 但是有些同学对这个概念似懂非懂,不知道怎么实现,怎么用,用在哪,甚至有些人认为yield就是协程! 我始终相信,如果你无法准确地表达出一个知识点的话 ...
- requirements基本使用
requirements作用描述:很多 Python 项目中经常会包含一个 requirements.txt 文件,里面内容是项目的依赖包及其对应版本号的信息列表,即项目依赖关系清单,其作用是用来重新 ...
- History和Screen的对象属性
History 对象是 window 对象的一部分,可通过 window.history 属性对其进行访问. 属性 说明 length 返回历史列表中的网址数 History 对象方法 方法 说明 b ...