MySQL更新时Error Code:1093和Error Code:1175的解决办法_MySQL, Oracle及数据库讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  MySQL, Oracle及数据库讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 2659 | 回复: 0   主题: MySQL更新时Error Code:1093和Error Code:1175的解决办法        下一篇 
无止境
注册用户
等级:新兵
经验:64
发帖:74
精华:0
注册:2011-11-14
状态:离线
发送短消息息给无止境 加好友    发送短消息息给无止境 发消息
发表于: IP:您无权察看 2014-11-11 15:46:38 | [全部帖] [楼主帖] 楼主

MySQL更新时Error Code:1093和Error Code:1175的解决办法

MySQLSQL
Error Code: 1093. You can't specify target table 'ws_product' for update in FROM clause


这个是我们在使用update或者delete语句时,在where条件里面加入的子查询导致的。例如如下的update语句:

?

1

2

3


updatetablesettype = 'static'whereid in(

selectid fromws_product wherefirst_name ='superman'

);


修改上述语句为下面这样,该问题可以解决:

?

1

2

3

4

5


updatews_product settype = 'static'whereid in(

selectid form (

selectid fromws_product wherefirst_name ='superman'

) xx

);


Error Code: 1175. You are using safe update mode and you tried to update a table without a WHERE that uses a KEY column To disable safe mode, toggle the option in Preferences -> SQL Queries and reconnect.


解决办法是在当前session下执行如下的语句

?

1


SETSQL_SAFE_UPDATES = 0;



然后再执行Update语句

--转自 北京联动北方科技有限公司




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论