码迷,mamicode.com
首页 > 数据库 > 详细

Mysql运行模式及1690错误处理

时间:2020-01-13 00:53:58      阅读:105      评论:0      收藏:0      [点我收藏+]

标签:out   个数   sig   rest   关于   一个   允许   and   产生   

Mysql运行模式及1690错误处理 MySQL said: Documentation

1690 - BIGINT UNSIGNED value is out of range in

经过查询,发现这个错误的原因是两个时间字段进行减法运算时,如果有一个时间为0000-00-00时造成的,根本原因是因为这样减法的结果会超过Mysql数值字段的范围,从而触发1690报错。

ERROR 1690 Out-of-Range
当Mysql中的数字字段存储了一个超过允许范围的数字时,会触发1690 Out of Range错误,是否触发错误取决于SQL运行时的模式:

当标准 Standar Mode 或 Strict Mode 运行时,数据插入会失败
当非限制模式 No Restrictive 运行时,Mysql将数值转化为范围允许内的最大或最小值进行存储

解决方法

SET sql_mode = ‘NO_UNSIGNED_SUBTRACTION‘;

在进行计算时,首先执行上面的语句,可以避免减法运算过程中的错误。在Mysql文档中,明确指出两个整数进行相减运算的结果是一个无符号数,在Mysql 5.5.5 之前,如果产生一个负数,mysql会将这个数转换为一个最大的数值。

自Mysql 5.5.5 之后,如果产生一个负数,则会产生一个错误 ERROR 1690。

关于SQL_MODE
SQL_MODE默认为空,有很多的选项,建议在生产环境中设置成严格的MODE,这样可以在运维期间避免很多麻烦。

Mysql运行模式及1690错误处理

标签:out   个数   sig   rest   关于   一个   允许   and   产生   

原文地址:https://blog.51cto.com/bulongxida/2466257

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!