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 展开
想通过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 展开
3个回答
展开全部
做第一个操作:
更新
content
的内容为
content
.
这里,
就是一个简单的修改,
然后修改表里面所有的
content
字段里面的数据.
都会把字段为
content
的值,
修改成
content
,
这个是最简单的更新数据的情况.
但是这个一般不实用,
我在开发的过程中,
也很少使用到这种情况.
因为有些表里面不是一条,
2条数据,
有可能就是上百万的数据.
更新一下,
就够你哭的了.
第一个图,
是查询出来数据,
然后在执行更新.
然后会发现表里面所有的content字段的值都变成了content了.
更新
content
的内容为
content
.
这里,
就是一个简单的修改,
然后修改表里面所有的
content
字段里面的数据.
都会把字段为
content
的值,
修改成
content
,
这个是最简单的更新数据的情况.
但是这个一般不实用,
我在开发的过程中,
也很少使用到这种情况.
因为有些表里面不是一条,
2条数据,
有可能就是上百万的数据.
更新一下,
就够你哭的了.
第一个图,
是查询出来数据,
然后在执行更新.
然后会发现表里面所有的content字段的值都变成了content了.
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
不允许这样写。。
可以换做
update net_subnetinfo a, net_subnetinfo b set a.leaf = 1 where a.id = b.pid;
可以换做
update net_subnetinfo a, net_subnetinfo b set a.leaf = 1 where a.id = b.pid;
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
复合语句中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
update net_subnetinfo set leaf =1 where subnetID in ( SELECT DISTINCT pSubnetID from net_subnetinfo_temp)
http://www.lxway.com/849551616.htm
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询