我试图更新访问的列,使其值为1。我使用MySQL工作台,我从工作台内部在SQL编辑器中编写语句。我正在写下面的命令:

UPDATE tablename SET columnname=1;

它给了我以下错误:

您正在使用安全更新模式,并且试图在没有 若要禁用安全模式,请切换该选项 ....

我按照说明,我从编辑菜单中取消了安全更新选项,然后是首选项,然后是SQL编辑器。同样的错误仍然出现&我无法更新此值。求你了,告诉我怎么了?


当前回答

看起来你的MySql会话有安全更新选项集。这意味着如果在where子句中没有指定键(例如主键),就不能更新或删除记录。

Try:

SET SQL_SAFE_UPDATES = 0;

或者您可以修改您的查询以遵循规则(在where子句中使用主键)。

其他回答

这适用于Mac,但对于其他操作系统必须相同,除了首选项的位置。

尝试不安全的DELETE操作时得到的错误

在新窗口中,取消选中“安全更新”选项

然后关闭并重新打开连接。无需重新启动服务。

现在我们将再次尝试DELETE,并获得成功的结果。

那么这些安全更新到底是怎么回事呢?这不是一件坏事。这就是MySql的说法。

使用——safe-updates选项

For beginners, a useful startup option is --safe-updates (or --i-am-a-dummy, which has the same effect). It is helpful for cases when you might have issued a DELETE FROM tbl_name statement but forgotten the WHERE clause. Normally, such a statement deletes all rows from the table. With --safe-updates, you can delete rows only by specifying the key values that identify them. This helps prevent accidents. When you use the --safe-updates option, mysql issues the following statement when it connects to the MySQL server:

SET sql_safe_updates=1, sql_select_limit=1000, sql_max_join_size=1000000;

在处理生产数据库时,打开这个选项是安全的。否则,您必须非常小心,不要意外删除重要数据。

第一: 请确保您想要更新该表中的所有记录,因为如果没有where子句,更新该表中的所有记录是危险的。很少需要更新表中的所有记录。

大多数时候,你想要更新特定的记录,其中应该包括where cluase,如果你再次想要更新所有的记录,打开MySQL工作台>编辑>首选项>SQL编辑>向下滚动,并取消选中“安全更新(拒绝更新和删除没有限制)”。

这是为了安全更新。

如果您取消选中上面所说的,那么您可能会更新所有记录,而不是导致数据库备份恢复的一条记录。没有回滚。

我刚刚添加了COMMIT;最后

SET SQL_SAFE_UPDATES=0;
UPDATE tablename SET columnname=1;
SET SQL_SAFE_UPDATES=1;
SET SQL_SAFE_UPDATES=0;

OR

点击编辑——>首选项

单击“SQL查询”页签,取消选中“安全更新”复选框

查询——>重新连接服务器

现在执行sql查询