NO_UNSIGNED_SUBTRACT SQL 模式的用途是什么,它在处理溢出中发挥了什么作用?


在启用 SQL 严格模式的情况下,其中一个类型为 UNSIGNED 的整数值之间的减法在默认情况下会产生一个无符号结果。但是,如果结果为负数,MySQL 则会产生一个错误。可以使用以下示例进行观察:

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)'

上述查询之后的错误显示它是在数值算术表达式之后发生溢出。

现在,可以使用启用 NO_UNSIGNED_SUBTRACTION SQL 模式的方式来处理它。启用此模式后,结果将是 -1,而不是一个错误。

mysql> Set sql_mode = 'NO_UNSIGNED_SUBTRACTION';
Query OK, 0 rows affected (0.00 sec)

mysql> Select CAST(0 AS UNSIGNED) -1;
+------------------------+
| CAST(0 AS UNSIGNED) -1 |
+------------------------+
|                     -1 |
+------------------------+
1 row in set (0.00 sec)

更新于:2020 年 1 月 30 日

293 次浏览

开启你的 职业生涯

完成课程,获得认证

开始学习
广告
© . All rights reserved.