mysql update 语句的问题

表结构net_subnetinfo(subnetIDint,intleaf,pSubnetIDint)subnetID表主键leaf是否叶节点,pSubnetID父节点i... 表结构 net_subnetinfo(subnetID int, int leaf, pSubnetID int) subnetID 表主键 leaf 是否叶节点,pSubnetID 父节点id

想通过sql将所有没有子节点的数据的leaf属性设置为1 sql及错误提示如下,

[SQL] update net_subnetinfo set leaf =1 where subnetID in ( SELECT DISTINCT pSubnetID from net_subnetinfo )

[Err] 1093 - You can't specify target table 'net_subnetinfo' for update in FROM clause
展开
 我来答
燕卿芮艳
2020-10-14 · TA获得超过1215个赞
知道小有建树答主
回答量:1825
采纳率:90%
帮助的人:10万
展开全部
做第一个操作:
更新
content
的内容为
content
.
这里,
就是一个简单的修改,
然后修改表里面所有的
content
字段里面的数据.
都会把字段为
content
的值,
修改成
content
,
这个是最简单的更新数据的情况.
但是这个一般不实用,
我在开发的过程中,
也很少使用到这种情况.
因为有些表里面不是一条,
2条数据,
有可能就是上百万的数据.
更新一下,
就够你哭的了.
第一个图,
是查询出来数据,
然后在执行更新.
然后会发现表里面所有的content字段的值都变成了content了.
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
154406720
2017-09-22 · TA获得超过169个赞
知道答主
回答量:116
采纳率:86%
帮助的人:57.9万
展开全部
不允许这样写。。

可以换做
update net_subnetinfo a, net_subnetinfo b set a.leaf = 1 where a.id = b.pid;
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
6fone
2015-10-19 · TA获得超过804个赞
知道小有建树答主
回答量:631
采纳率:33%
帮助的人:539万
展开全部
复合语句中update和select不能操作同一个表,你可以创建一个临时表net_subnetinfo_temp,它里面的数据和net_subnetinfo数据一样:

update net_subnetinfo set leaf =1 where subnetID in ( SELECT DISTINCT pSubnetID from net_subnetinfo_temp)

http://www.lxway.com/849551616.htm
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式