如何让 MySQL 截断数据而不是在插入时引发错误?

Mary-Kate Olsen
发布: 2024-11-05 01:46:02
原创
219 人浏览过

How to Make MySQL Truncate Data Instead of Raising an Error on Insert?

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中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板