MySQL Incorrect integer value: '' for column 'xxx' at row xxx 错误


Incorrect integer value: '' for column 'xxx' at row xxx

报错的环境

其他场景报这个错也可以使用这种解决方式
使用 LOAD DATA LOCAL INFIL 将文本数据加载到 MySQL 时抛出了以下异常
Incorrect integer value: '' for column 'xxx' at row xxx

解决方式

  • 查询当前 MySQL 的 SQL Mode
SELECT @@sql_mode

记录下回显信息, 我的 sql_mode 的值如下

ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION
  • 删除 sql_mode 变量中的 STRICT_TRANS_TABLES 值
set @@sql_mode=ONLY_FULL_GROUP_BY,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION
  • 也可以将 sql_mode 参数写在 MySQL 配置文件中, 在 my.cnf 中添加如下配置
sql_mode=ONLY_FULL_GROUP_BY,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

如果上面的解决方式不奏效

修改 sql_mode 的值为 NO_ENGINE_SUBSTITUTION

sql_mode=NO_ENGINE_SUBSTITUTION


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM