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
展开
 我来答
百度网友13eda02
2015-01-29 · TA获得超过778个赞
知道小有建树答主
回答量:1048
采纳率:77%
帮助的人:379万
展开全部

按照描述这么写:

update 表名 t1
set t1.name=(
select name from 表名 t2
where t2.pid=t1.pid and t2.name is not null and rownum=1
)
where t1.name is null;
追问
你这个是oracle,不是mysql,
我早就用过这种语法了
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式