我试图更新访问的列,使其值为1。我使用MySQL工作台,我从工作台内部在SQL编辑器中编写语句。我正在写下面的命令:
UPDATE tablename SET columnname=1;
它给了我以下错误:
您正在使用安全更新模式,并且试图在没有 若要禁用安全模式,请切换该选项 ....
我按照说明,我从编辑菜单中取消了安全更新选项,然后是首选项,然后是SQL编辑器。同样的错误仍然出现&我无法更新此值。求你了,告诉我怎么了?
我试图更新访问的列,使其值为1。我使用MySQL工作台,我从工作台内部在SQL编辑器中编写语句。我正在写下面的命令:
UPDATE tablename SET columnname=1;
它给了我以下错误:
您正在使用安全更新模式,并且试图在没有 若要禁用安全模式,请切换该选项 ....
我按照说明,我从编辑菜单中取消了安全更新选项,然后是首选项,然后是SQL编辑器。同样的错误仍然出现&我无法更新此值。求你了,告诉我怎么了?
当前回答
我也有同样的问题,但当我关闭“安全更新”在编辑-> 首选项-> SQL编辑器->安全更新,我仍然使用面对 错误码为“1175禁用安全模式”
我对这个错误的解决方案只是给出了表的主键,如果没有给出,并使用这些主键值更新列。
例如:UPDATE[表名]SET Empty_Column = 'Value' WHERE [主键列名]= value;
其他回答
我找到了答案。问题是我必须在表名之前加上模式名。也就是说,命令应该是:
UPDATE schemaname.tablename SET columnname=1;
谢谢所有。
第一: 请确保您想要更新该表中的所有记录,因为如果没有where子句,更新该表中的所有记录是危险的。很少需要更新表中的所有记录。
大多数时候,你想要更新特定的记录,其中应该包括where cluase,如果你再次想要更新所有的记录,打开MySQL工作台>编辑>首选项>SQL编辑>向下滚动,并取消选中“安全更新(拒绝更新和删除没有限制)”。
这是为了安全更新。
如果您取消选中上面所说的,那么您可能会更新所有记录,而不是导致数据库备份恢复的一条记录。没有回滚。
看起来你的MySql会话有安全更新选项集。这意味着如果在where子句中没有指定键(例如主键),就不能更新或删除记录。
Try:
SET SQL_SAFE_UPDATES = 0;
或者您可以修改您的查询以遵循规则(在where子句中使用主键)。
我也有同样的问题,但当我关闭“安全更新”在编辑-> 首选项-> SQL编辑器->安全更新,我仍然使用面对 错误码为“1175禁用安全模式”
我对这个错误的解决方案只是给出了表的主键,如果没有给出,并使用这些主键值更新列。
例如:UPDATE[表名]SET Empty_Column = 'Value' WHERE [主键列名]= value;
如果处于安全模式,则需要在where子句中提供id。所以像这样的东西应该可以工作!
UPDATE tablename SET columnname=1 where id>0