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