mysql多表关联更新问题
假设表字段和数据:idpidname11a21b31空42c52d62e72空在mysql中,想用一条sql,把空name的更新为pid相等的任意一条记录的name,要怎...
假设表字段和数据:
id pid name
1 1 a
2 1 b
3 1 空
4 2 c
5 2 d
6 2 e
7 2 空
在mysql中,想用一条sql,把空name的更新为pid相等的任意一条记录的name,要怎么操作呢?
最后的结果,id为3的name可以为a,也可以为b,id为7的name可以为cde之一,都可以,求教
这种写法是错误的:
update tb1 a set a.name=(select b.name from tb1 b where a.pid=b.pid and a.id<>b.id limit 1) where a.name is null
后面自己解决了:
update tb1 a , (select pid,name from tb1 where name is not null group by pid) b
set a.name=b.n
where a.name is null
and a.pid=b.pid 展开
id pid name
1 1 a
2 1 b
3 1 空
4 2 c
5 2 d
6 2 e
7 2 空
在mysql中,想用一条sql,把空name的更新为pid相等的任意一条记录的name,要怎么操作呢?
最后的结果,id为3的name可以为a,也可以为b,id为7的name可以为cde之一,都可以,求教
这种写法是错误的:
update tb1 a set a.name=(select b.name from tb1 b where a.pid=b.pid and a.id<>b.id limit 1) where a.name is null
后面自己解决了:
update tb1 a , (select pid,name from tb1 where name is not null group by pid) b
set a.name=b.n
where a.name is null
and a.pid=b.pid 展开
1个回答
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询