Mysql运行模式及1690错误处理
发布时间:2023-02-16 14:30:28 所属栏目:MySql 来源:互联网
导读:1690 - BIGINT UNSIGNED value is out of range in 经过查询,发现这个错误的原因是两个时间字段进行减法运算时,如果有一个时间为0000-00-00时造成的,根本原因是因为这样减法的结果会超过MysqL数值字段的范围,从而触发1690报错。 ERROR 1690 Out-of-Range
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。 (编辑:莱芜站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐
- mysql – 选择datetime大于指定日期的记录
- Linux 关于MySQL权限分配的详解
- php – 使用mysql在15分钟的插槽中分割时间间隔
- mysql – SailsJS – 如何在创建记录时指定字符串
- mysql – 如何使用mongify将两个表合并为一个表
- 按照cakephp group by table的格式在核心php中检
- php singleton数据库连接,这个代码是不好的做法?
- mysql – 将数据从SQL移动到Aerospike
- 为什么SQLAlchemy create_engine与charset = utf
- Mysql学习MySQL存储引擎中MyISAM和InnoDB区别详解
热点阅读