翠花爱上了铁牛 2024-09-26 11:38 采纳率: 20%
浏览 4

Orcale联表分组求和

我有一个表A结构和数据如下:
Id Code Qty


1 a 2
1 b 5
2 a 3
2 c 10
3 a 4
4 d 6

以及另一个表B
Id1 Id2


1 2
3 4

表A中 id和B中ID1和ID2都可能相等
现在我想要查询表A中,如果ID是表B中同一行的两个ID,则将A中这两个ID按code分组求和,最后保留ID1。
即实现查询结果为:
ID1 Code Totol_QTY
1 a 5
1 b 5
1 c 10
3 a 4
3 d 6

请问sql应该怎样写效率高一点呢

  • 写回答

1条回答 默认 最新

  • 一轮明月照丘壑 2024-09-28 21:53
    关注

    以下回复参考:皆我百晓生券券喵儿等免费微信小程序作答:

    为了实现你的需求,你可以使用Oracle中的JOIN操作来连接表A和表B,然后使用GROUP BY和聚合函数SUM来按Code分组并求和。以下是一个可能的SQL查询:

    SELECT A.ID1 AS ID, A.Code, SUM(A.Qty) AS Total_QTY
    FROM 
        (SELECT A.Id AS ID1, B.Id2 AS ID2, A.Code, A.Qty
         FROM TableA A
         JOIN TableB B ON A.Id = B.Id1) A
    GROUP BY A.ID1, A.Code;
    

    这个查询首先在子查询中连接了表A和表B,根据它们的Id值进行匹配。然后在外层查询中,根据ID1和Code进行分组并计算总数量。这将给出你想要的结果。在这个查询中,假设ID是你的主键并且它们是唯一的。如果不是这样,你可能需要进行适当的调整。

    评论

报告相同问题?

问题事件

  • 创建了问题 9月26日

悬赏问题

  • ¥15 如何在vue.config.js中读取到public文件夹下window.APP_CONFIG.API_BASE_URL的值
  • ¥50 浦育平台scratch图形化编程
  • ¥20 求这个的原理图 只要原理图
  • ¥15 vue2项目中,如何配置环境,可以在打完包之后修改请求的服务器地址
  • ¥20 微信的店铺小程序如何修改背景图
  • ¥15 UE5.1局部变量对蓝图不可见
  • ¥15 一共有五道问题关于整数幂的运算还有房间号码 还有网络密码的解答?(语言-python)
  • ¥20 sentry如何捕获上传Android ndk 崩溃
  • ¥15 在做logistic回归模型限制性立方条图时候,不能出完整图的困难
  • ¥15 G0系列单片机HAL库中景园gc9307液晶驱动芯片无法使用硬件SPI+DMA驱动,如何解决?