oracle如何通过两个表关联,修改其中一表中某列的数据?
举例说明:orale下A表有E、F、G列B表有G、H、I列两表关联的列为G现要求根据关联的G列使A表中的E列等于B表中的H列。求教。谢谢。注意是在oracle下。根据你的...
举例说明:orale下
A表有E、F、G列 B表有G、H、I列两表关联的列为G
现要求根据关联的G列 使A表中的E列等于B表中的H列。
求教。谢谢。注意是在oracle下。
根据你的说法写的语句update XS0706 set XS0706.BJBH=XS0101.BJBH where XS0706.XH=XS0101.XH 提示标识符错误。 展开
A表有E、F、G列 B表有G、H、I列两表关联的列为G
现要求根据关联的G列 使A表中的E列等于B表中的H列。
求教。谢谢。注意是在oracle下。
根据你的说法写的语句update XS0706 set XS0706.BJBH=XS0101.BJBH where XS0706.XH=XS0101.XH 提示标识符错误。 展开
4个回答
展开全部
update a set a.e=(select b.h from b where b.g=a.g)
where a.g in (select b.g from b)
或者
update a set a.e=(select b.h from b where b.g=a.g)
where exists (select null from b where b.g=a.g)
需要保证a,b表一对一对应关系,如不是不可以这么写
条件那里看需要写了,如果a表大,用in ,反之用exists
where a.g in (select b.g from b)
或者
update a set a.e=(select b.h from b where b.g=a.g)
where exists (select null from b where b.g=a.g)
需要保证a,b表一对一对应关系,如不是不可以这么写
条件那里看需要写了,如果a表大,用in ,反之用exists
展开全部
update A set A.E=B.H where A.G in(select B.G from B)
楼主,我一直用的就是oracle数据库啊 ,可能不是语句错误,搞不好是主键的问题啊,A,B表的主键就一个且是G吗?
这样试试看呢
楼主,我一直用的就是oracle数据库啊 ,可能不是语句错误,搞不好是主键的问题啊,A,B表的主键就一个且是G吗?
这样试试看呢
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
update A set A.E=(select B.H from B where A.G=B.G)
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
update A set A.E=B.H where A.G=B.G
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询