oracle查询表A品名字段,更新表B品名字段
表a和表b中都有重复记录,以下图示给出表a,表b,以及update后的表b,就是利用学号相同这一点在表a中查询出爱好这个字段,将结果更新到表b的特长字段下...
表a和表b中都有重复记录,以下图示给出表a,表b,以及update后的表b,就是利用学号相同这一点在表a中查询出爱好这个字段,将结果更新到表b的特长字段下
展开
4个回答
展开全部
追问
你说的很详细,也很对,就是不是oracle数据库的,这个group_concat是mysql的,oracle中没这个,相同功能的函数行转列是wm_concat,而且你写的这个语法有点没看懂,score s 和hobby a是哪来的表?这个可能跟oracle不太一样,没整明白
追答
score 和hobby是我自己建的两张表。 s,a是这两张表的别名。
兄弟,我这也是给你个思路,具体在oracle中是用哪个函数,你可以查一下,
但是你必须要有思路,才能写出来。这对你以后写sql都是很必要的。请采纳我
展开全部
实现思路就是通过两个表的关联字段,之后将结果更新到另外一个表中:
sql:update b set a3=(select a3 from a where a.a1=b.b1 and a.a2=b.b2)
备注:使用上边语句,不存在b表中的a表数据不会被更新。
sql:update b set a3=(select a3 from a where a.a1=b.b1 and a.a2=b.b2)
备注:使用上边语句,不存在b表中的a表数据不会被更新。
追问
sql:update b set a3=(select a3 from a where a.a1=b.b1 and a.a2=b.b2),这个语句的确可以更新,但是是在a表中学号字段不重复的情况下才有效,现在情况是学号字段重复,存在一对多的情况,无法更新
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
sql:update b set a3=(select a3 from a where a.a1=b.b1 and a.a2=b.b2)
追问
sql:update b set a3=(select a3 from a where a.a1=b.b1 and a.a2=b.b2),这个语句的确可以更新,但是是在a表中学号字段不重复的情况下才有效,现在情况是学号字段重复,存在一对多的情况,无法更新
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |