mysql sql_mode数据验证检查方法

 更新时间:2023年08月25日 11:24:13   作者:Ares-Wang  
sql_mode 会影响MySQL支持的sql语法以及执行的数据验证检查,通过设置sql_mode ,可以完成不同严格程度的数据校验,有效地保障数据准确性,这篇文章主要介绍了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 参数值 可以设置

到此这篇关于mysql sql_mode数据验证检查的文章就介绍到这了,更多相关mysql sql_mode数据验证内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL数据库char与varchar的区别分析及使用建议

    MySQL数据库char与varchar的区别分析及使用建议

    本文主要介绍了mysql中VARCHAR与CHAR字符型数据的差异以及这两种字符型数据在项目中的使用建议,真心不错。值得一看。小编有种受益匪浅的感觉。
    2014-09-09
  • MySQL中的count(*) 和 count(1) 区别性能对比分析

    MySQL中的count(*) 和 count(1) 区别性能对比分析

    这篇文章主要介绍了MySQL中的count(*)和count(1)区别性能对比,本节还介绍了我们常说的索引下推,结合实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2023-05-05
  • MySQL数据导入导出的三种办法总结

    MySQL数据导入导出的三种办法总结

    当我们需要切换数据库或备份数据时,导入和导出数据库是一个常见的操作,下面这篇文章主要给大家介绍了关于MySQL数据导入导出的三种办法,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-05-05
  • Mac下MySQL安装配置教程

    Mac下MySQL安装配置教程

    这篇文章主要为大家详细介绍了Mac下MySQL安装配置教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-05-05
  • mysql创建学生表、课程表及学生选课表详细代码

    mysql创建学生表、课程表及学生选课表详细代码

    这篇文章主要给大家介绍了mysql创建学生表、课程表及学生选课表的相关资料,学生、课程以及成绩的增删改查都是建立在连接数据库的基础之上,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2023-12-12
  • 解决Mysql主从同步时Slave_IO_Running:Connecting;Slave_SQL_Running:Yes的故障排除问题

    解决Mysql主从同步时Slave_IO_Running:Connecting;Slave_SQL_Running:Ye

    排查MySQL主从复制错误,依次检查网络、账户密码、防火墙,确认桥接模式、互ping通、防火墙关闭;检查配置文件log_bin和server_id,验证连接语法及主服务器权限设置,确保IP允许访问
    2025-07-07
  • MySQL数据库高可用HA实现小结

    MySQL数据库高可用HA实现小结

    MySQL数据库是目前开源应用最大的关系型数据库,有海量的应用将数据存储在MySQL数据库中,这篇文章主要介绍了MySQL数据库高可用HA实现,需要的朋友可以参考下
    2022-01-01
  • Mysql树形结构的数据库表设计方案

    Mysql树形结构的数据库表设计方案

    树形结构对大家来说应该都不陌生,在日常开发中经常会遇到,下面这篇文章主要给大家介绍了关于Mysql树形结构的数据库表设计的相关资料,文中通过示例代码的非常详细,需要的朋友可以参考下
    2021-09-09
  • ubuntu 15.04下mysql开放远程3306端口

    ubuntu 15.04下mysql开放远程3306端口

    这篇文章主要为大家详细介绍了ubuntu 15.04开放mysql远程3306端口的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-01-01
  • mysql如何动态创建连续时间段

    mysql如何动态创建连续时间段

    这篇文章主要介绍了mysql如何动态创建连续时间段问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-01-01

最新评论