csxiaoz 2016-07-25 11:05 采纳率: 50%
浏览 1353
已采纳

sql 主细表多对多关系求和问题

user表 :userid,username
主表tablea:aid,userid,date,anum
细表tableb:bid,aid,date,bnum
user表对应多张talbea,tablea对应多张tableb。
想要的结果集用户名,日期,该天的anum之和,bnum之和。
username,date,anum,bnum.
我开始想的是select username,date,sum(anum),sum(bnum)
from user u left join tablea a on u.userid=a.userid
left join tableb b on b.aid =a.aid.
后来觉得这样 sum(anum)会有重复的。
那么正确的应该怎么写呢。手头没有数据库客户端,只能凭空想象。

  • 写回答

1条回答 默认 最新

  • w362335821 2016-07-28 03:42
    关注

    select username,date,count(distinct aid),count(bid)
    from user u left join tablea a on u.userid=a.userid
    left join tableb b on b.aid =a.aid.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料