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