MySQL 插入行为:截断与错误
MySQL 在尝试插入超过列长度限制的数据时表现出不同的行为:截断或错误。在这种情况下,我们的目标是修改 MySQL 实例以截断数据而不是引发错误。
解决方案:禁用 STRICT_TRANS_TABLES 和 STRICT_ALL_TABLES
默认情况下,MySQL 强制执行严格的模式,其中包括设置 STRICT_TRANS_TABLES 和 STRICT_ALL_TABLES。这些设置禁止在 INSERT 或 UPDATE 等数据更改操作中出现无效或缺失值。
为了允许自动截断插入的字符串,我们可以禁用 STRICT_TRANS_TABLES 和 STRICT_ALL_TABLES。操作方法如下:
<code class="sql">SET SESSION sql_mode=NO_STRICT_TRANS_TABLES,NO_STRICT_ALL_TABLES;</code>
说明:
通过禁用这些设置,我们删除了对无效或缺失值的限制。这允许 MySQL 以静默方式截断超过列长度限制的数据,遵循截断的默认行为。
参考:
MySQL Server SQL 模式:https:// /dev.mysql.com/doc/refman/8.0/en/sql-mode.html
以上是如何让 MySQL 截断数据而不是在插入时引发错误?的详细内容。更多信息请关注PHP中文网其他相关文章!