我试图更新访问的列,使其值为1。我使用MySQL工作台,我从工作台内部在SQL编辑器中编写语句。我正在写下面的命令:
UPDATE tablename SET columnname=1;
它给了我以下错误:
您正在使用安全更新模式,并且试图在没有 若要禁用安全模式,请切换该选项 ....
我按照说明,我从编辑菜单中取消了安全更新选项,然后是首选项,然后是SQL编辑器。同样的错误仍然出现&我无法更新此值。求你了,告诉我怎么了?
我试图更新访问的列,使其值为1。我使用MySQL工作台,我从工作台内部在SQL编辑器中编写语句。我正在写下面的命令:
UPDATE tablename SET columnname=1;
它给了我以下错误:
您正在使用安全更新模式,并且试图在没有 若要禁用安全模式,请切换该选项 ....
我按照说明,我从编辑菜单中取消了安全更新选项,然后是首选项,然后是SQL编辑器。同样的错误仍然出现&我无法更新此值。求你了,告诉我怎么了?
当前回答
在工作台上,我通过禁用安全更新模式解决了这个问题:
-编辑->首选项-> Sql编辑器然后取消安全更新。
其他回答
SET SQL_SAFE_UPDATES=0;
UPDATE tablename SET columnname=1;
SET SQL_SAFE_UPDATES=1;
只需输入SET SQL_SAFE_UPDATES = 0;在删除或更新之前,重新设置为1 设置sql_safe_updates = 1
看起来你的MySql会话有安全更新选项集。这意味着如果在where子句中没有指定键(例如主键),就不能更新或删除记录。
Try:
SET SQL_SAFE_UPDATES = 0;
或者您可以修改您的查询以遵循规则(在where子句中使用主键)。
我刚刚添加了COMMIT;最后
不需要将SQL_SAFE_UPDATES设置为0,我真的不鼓励这样做。SAFE_UPDATES默认开启是有原因的。你可以不用安全带和其他东西开车,如果你知道我的意思;) 只需在WHERE子句中添加一个KEY-value,该KEY-value匹配所有内容,例如与0相比的主键,因此不必写:
UPDATE customers SET countryCode = 'USA'
WHERE country = 'USA'; -- which gives the error, you just write:
UPDATE customers SET countryCode = 'USA'
WHERE (country = 'USA' AND customerNumber <> 0); -- Because customerNumber is a primary key you got no error 1175 any more.
现在你可以放心,每一个记录(总是)更新如你所期望的。