mysql sql_mode数据验证检查

sql_mode 功能

sql_mode 会影响MySQL支持的sql语法以及执行的数据验证检查。通过设置sql_mode ,可以完成不同严格程度的数据校验,有效地保障数据准确性

sql_mode 严格模式 VS 宽松模式

宽松模式
比如,插入的数据不满足 表的数据类型,也可能接受,并且不报错,只会有警告而且。
一个字段设置 char(10),如果插入 1234567890ABC,会ABC会自动舍去,只保留1234567890,sql不报错的。
在这里插入图片描述

** 严格模式 ** 默认是严格模式
插入数据类型,不能隐式转换的,最终就会报错。
长度规定长度,会报错。

设置sql_mode

临时设置模式
set global sql_mode =‘XXXX’ ; ## 全局 重启mysql 服务 就失效
set session sql_mode=‘XXXX’; ## 当前会话 关闭会话 就失效
永久设置模式
windows 系统 设置 my.ini (一般位置 C:\ProgramData\MySQL\MySQL Server 5.7 | C:\ProgramData\MySQL\MySQL Server 8.0),
但 要重启 mysql 服务 才生效
在这里插入图片描述
linux /etc/my.cnf

生成环境,一般不能随便重启 mysql服务的,所有采用 临时设置方法+永久设置方式 来解决线上问题。

查看mysql sql_mode

show variables like ‘sql_mode’;

select @@global.sql_mode;

select @@session.sql_mode;

select sql_mode
在这里插入图片描述
在这里插入图片描述

sql_mode 参数值 可以设置

在这里插入图片描述文章来源地址https://uudwc.com/A/AB2Ea

原文地址:https://blog.csdn.net/u013400314/article/details/132477285

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请联系站长进行投诉反馈,一经查实,立即删除!

h
上一篇 2023年08月25日 16:22
下一篇 2023年08月25日 16:22