Mysql ERROR 1175 - SQL_SAFE_UPDATES
摘要
Mysql 报错 ERROR 1175, 是因为启动的时候开启了
安全更新模式
导致的
报错信息如下
1 | ERROR 1175 (HY000): You are using safe update mode and you tried to update a table without a WHERE that uses a KEY column |
SQL_SAFE_UPDATES
这个报错是因为在更新表的时候where条件中没有到没有含有KEY的列导致的
。
另外更新的时候没有where条件
也会报类似的错误
1 | root@127.0.0.1 : auditAdmin 16:54:10> create table lc_temp(id int,name varchar(20)) ; |
注意开头提示的“你在使用安全更新模式”,参考Mysql官网,在启动mysql的时候使用”安全更新模式 --safe-updates
“相当于设置了如下命令SET sql_safe_updates=1, sql_select_limit=1000, max_join_size=1000000;
附加
这里说明下sql_select_limit
参数,为了防止出现不带where条件的全表查询导致资源浪费。如果表中的记录大于1000条的时候,只显示1000条记录
有两种方式解决
## modify sql_safe_updates
set sql_safe_updates=0;
set sql_safe_updates=off;
## limit
select username from userinfo limit 10001;
当报错的时候检查,这个变量是开启的状态
1 | root@127.0.0.1 : (none) 16:42:44> show variables like '%SQL_SAFE_UPDATES%'; |
修改为OFF
或者0
SET sql_safe_updates = 0;
SET sql_safe_updates = OFF;
再去执行update,就没有问题
Refer to mysql-tips
公众号: DailyJobOps

Mysql ERROR 1175 - SQL_SAFE_UPDATES
http://blog.colinspace.com/2016/12/13/2016-12-13-Mysql-ERROR-1175-SQL-SAFE-UPDATES/