博客
关于我
mysql的sql_mode合理设置
阅读量:432 次
发布时间:2019-03-06

本文共 1187 字,大约阅读时间需要 3 分钟。

MySQL SQL_MODE设置建议

作为一名开发人员,了解并合理设置MySQL的SQL_MODE是非常重要的。默认情况下,SQL_MODE是空值,这种设置虽然方便,但可能会导致一些潜在的问题。因此,在生产环境中,建议将SQL_MODE设置为严格模式,以便在开发和测试阶段发现潜在问题。

以下是几种常见的SQL_MODE设置及其作用:

GROUP BY聚合操作需要谨慎处理。在SELECT列表中包含未在GROUP BY中的字段时,SQL会抛出错误。这与标准SQL规范一致。

NO_AUTO_VALUE_ON_ZERO自增列在默认设置下允许插入0或NULL值。如果希望插入0到自增列时,可以使用这一设置。

STRICT_TRANS_TABLES在事务表中插入违反约束的数据会导致操作中断,而对非事务表没有约束。

NO_ZERO_IN_DATE严格模式下,不允许插入日期中的月份或日期为0。

NO_ZERO_DATE禁止插入零日期,插入零日期会抛出错误而非警告。

ERROR_FOR_DIVISION_BY_ZERO在插入或更新操作中,如果除数为零,会抛出错误而非警告。

NO_AUTO_CREATE_USER禁止GRANT命令创建密码为空的用户。

NO_ENGINE_SUBSTITUTION如果所需存储引擎被禁用或未编译,会抛出错误,而不是使用默认存储引擎。

PIPES_AS_CONCAT将"||"视为字符串连接符,与Oracle数据库和Concat函数类似。

ANSI_QUOTES启用后,双引号将被解释为识别符而非字符串引用符。

在MySQL中,建议将SQL_MODE设置为:ONLY_FULL_GROUP_BY, NO_AUTO_VALUE_ON_ZERO, STRICT_TRANS_TABLES, NO_ZERO_IN_DATE, NO_ZERO_DATE, ERROR_FOR_DIVISION_BY_ZERO, NO_AUTO_CREATE_USER, NO_ENGINE_SUBSTITUTION, PIPES_AS_CONCAT, ANSI_QUOTES。

在my.cnf文件中,可以通过以下配置实现这一点:

[mysqld]sql_mode='ONLY_FULL_GROUP_BY,NO_AUTO_VALUE_ON_ZERO,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION,PIPES_AS_CONCAT,ANSI_QUOTES'

这种设置既符合MySQL的标准,又兼容了Oracle的使用习惯。通过合理设置SQL_MODE,可以显著提升数据库的安全性和稳定性。

转载地址:http://zifyz.baihongyu.com/

你可能感兴趣的文章
STM32工作笔记0032---编写跑马灯实验---寄存器版本
查看>>
Static--用法介绍
查看>>
ssm旅游信息管理系统的设计与实现bus56(程序+开题)
查看>>
order by rand()
查看>>
SSM(Spring+SpringMvc+Mybatis)整合开发笔记
查看>>
ViewHolder的改进写法
查看>>
Orderer节点启动报错解决方案:Not bootstrapping because of 3 existing channels
查看>>
org.apache.axis2.AxisFault: org.apache.axis2.databinding.ADBException: Unexpected subelement profile
查看>>
sql查询中 查询字段数据类型 int 与 String 出现问题
查看>>
org.apache.commons.beanutils.BasicDynaBean cannot be cast to ...
查看>>
org.apache.dubbo.common.serialize.SerializationException: com.alibaba.fastjson2.JSONException: not s
查看>>
sqlserver学习笔记(三)—— 为数据库添加新的用户
查看>>
org.apache.http.conn.HttpHostConnectException: Connection to refused
查看>>
org.apache.ibatis.binding.BindingException: Invalid bound statement错误一例
查看>>
org.apache.ibatis.exceptions.PersistenceException:
查看>>
org.apache.ibatis.exceptions.TooManyResultsException: Expected one result (or null) to be returned
查看>>
org.apache.ibatis.type.TypeException: Could not resolve type alias 'xxxx'异常
查看>>
org.apache.poi.hssf.util.Region
查看>>
org.apache.xmlbeans.XmlOptions.setEntityExpansionLimit(I)Lorg/apache/xmlbeans/XmlOptions;
查看>>
org.apache.zookeeper.KeeperException$ConnectionLossException: KeeperErrorCode = ConnectionLoss for /
查看>>