MySQL 插入行为:截断与错误
MySQL 在尝试插入超出列长度限制的数据时表现出不同的行为:截断或错误。在这种情况下,我们的目标是修改 MySQL 实例以截断数据而不是引发错误。
解决方案:禁用 STRICT_TRANS_TABLES 和 STRICT_ALL_TABLES
默认情况下,MySQL 强制执行严格的模式,其中包括设置 STRICT_TRANS_TABLES 和 STRICT_ALL_TABLES。这些设置禁止在 INSERT 或 UPDATE 等数据更改操作中出现无效或缺失值。
为了允许自动截断插入的字符串,我们可以禁用 STRICT_TRANS_TABLES 和 STRICT_ALL_TABLES。操作方法如下:
SET SESSION sql_mode=NO_STRICT_TRANS_TABLES,NO_STRICT_ALL_TABLES;
说明:
通过禁用这些设置,我们删除对无效值或缺失值的限制。这允许 MySQL 以静默方式截断超过列长度限制的数据,遵循截断的默认行为。
参考:
MySQL Server SQL 模式:https:// /dev.mysql.com/doc/refman/8.0/en/sql-mode.html
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3