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)
广告
数据结构
网络
RDBMS
操作系统
Java
iOS
HTML
CSS
Android
Python
C 编程
C++
C#
MongoDB
MySQL
Javascript
PHP