文章目录
一、完整报错
txt
> 1054 - Unknown column 'user-test' in 'where clause'
二、报错数据
sql
SELECT *
FROM config_info
WHERE config_info.data_id="user-test"
三、报错原因
- 因为sql_mode里面有 ANSI_QUOTES,这个校验模式。所以导致报错
- ANSI_QUOTES:不能用双引号来引用字符串,因为它被解释为识别符
- 更改sql_mode详细过程,点击跳转
四、解决方式
1、更改执行sql
sql
SELECT *
FROM config_info
WHERE config_info.data_id='user-test'
2、更改sql数据校验模式(改为默认校验)
sql
SET GLOBAL sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';
SET SESSION sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';