oracle查询表A品名字段,更新表B品名字段

表a和表b中都有重复记录,以下图示给出表a,表b,以及update后的表b,就是利用学号相同这一点在表a中查询出爱好这个字段,将结果更新到表b的特长字段下... 表a和表b中都有重复记录,以下图示给出表a,表b,以及update后的表b,就是利用学号相同这一点在表a中查询出爱好这个字段,将结果更新到表b的特长字段下 展开
 我来答
Annie说情感

2019-01-17 · TA获得超过6559个赞
知道大有可为答主
回答量:2174
采纳率:76%
帮助的人:178万
展开全部

可以用一个函数做到,我举一个例子给你看。

这相当于你的A表

B1表

利用GROUP_CONCAT这个函数可以把我们查到的多条数据拼接,不过不要忘了加GROUP BY。

看如下查询语句的效果:

所以不难写出你的update语句

UPDATE score s set s.hobbys=(SELECT b.hobbys from(

SELECT a.num, GROUP_CONCAT(a.hobby) as hobbys FROM hobby a GROUP BY a.num

) as b WHERE b.num=s.num

执行完这个我们来看下原来的B表变成什么了

Ok了,执行成功!

希望能够帮到你,望采纳!

追问
你说的很详细,也很对,就是不是oracle数据库的,这个group_concat是mysql的,oracle中没这个,相同功能的函数行转列是wm_concat,而且你写的这个语法有点没看懂,score s 和hobby a是哪来的表?这个可能跟oracle不太一样,没整明白
追答
score 和hobby是我自己建的两张表。 s,a是这两张表的别名。

兄弟,我这也是给你个思路,具体在oracle中是用哪个函数,你可以查一下,

但是你必须要有思路,才能写出来。这对你以后写sql都是很必要的。请采纳我
智者总要千虑
高粉答主

2019-01-16 · 说的都是干货,快来关注
知道顶级答主
回答量:7.9万
采纳率:88%
帮助的人:1.3亿
展开全部
实现思路就是通过两个表的关联字段,之后将结果更新到另外一个表中:
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表中学号字段不重复的情况下才有效,现在情况是学号字段重复,存在一对多的情况,无法更新
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
己晓莉2P
2019-01-16
知道答主
回答量:26
采纳率:0%
帮助的人:1.9万
展开全部
不错,呀。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友e7c67a7
2019-01-17 · 贡献了超过448个回答
知道答主
回答量:448
采纳率:3%
帮助的人:34.6万
展开全部
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表中学号字段不重复的情况下才有效,现在情况是学号字段重复,存在一对多的情况,无法更新
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式