mysql报错1690_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> SET sql_mode = '';

mysql> SELECT CAST(0 AS UNSIGNED) - 1;

+-------------------------+

| CAST(0 AS UNSIGNED) - 1 |

+-------------------------+

| 18446744073709551615 |

+-------------------------+

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

mysql> SET sql_mode = '';

Query OK, 0 rows affected (0.00 sec)

mysql> SELECT CAST(0 AS UNSIGNED) - 1;

ERROR 1690 (22003): BIGINT UNSIGNED value is out of range in '(cast(0 as unsigned) - 1)'

关于SQL_MODE

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
报错 "only_full_group_by" 是 MySQL 数据库中的一个错误。它是由于在使用 GROUP BY 子句时,SELECT 语句中的列未在聚合函数中进行处理而导致的。 解决这个问题可以通过以下几种方式: 1. 使用聚合函数处理所有未在 GROUP BY 子句中的列:将 SELECT 语句中的列名添加到 GROUP BY 子句中或者将它们包装在相应的聚合函数(如 COUNT、SUM、MAX 等)中。 例如,如果你有以下的 SELECT 语句: ```sql SELECT id, name, SUM(quantity) FROM orders GROUP BY id; ``` 你可以修改为: ```sql SELECT id, name, SUM(quantity) FROM orders GROUP BY id, name; ``` 或者将未在 GROUP BY 子句中的列使用聚合函数处理: ```sql SELECT id, MAX(name) AS name, SUM(quantity) FROM orders GROUP BY id; ``` 2. 禁用 `ONLY_FULL_GROUP_BY` 模式:在会话级别或全局级别上修改 MySQL 配置,将 `sql_mode` 中的 `ONLY_FULL_GROUP_BY` 移除或替换为空字符串。请注意,这可能会导致其他潜在问题,因此需要谨慎使用。 例如,你可以执行以下 SQL 语句来禁用 `ONLY_FULL_GROUP_BY` 模式: ```sql SET GLOBAL sql_mode=(SELECT REPLACE(@@sql_mode,'ONLY_FULL_GROUP_BY','')); ``` 3. 更新 MySQL 版本:如果你正在使用较旧的 MySQL 版本,可以尝试升级到较新的版本。较新的 MySQL 版本通常对 SQL 标准的支持更好,可能会解决该问题。 请注意,在进行任何更改之前,请备份你的数据库以防意外发生。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值