免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2537 | 回复: 3
打印 上一主题 下一主题

求一个group by 语句写法 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-04-24 16:36 |只看该作者 |倒序浏览
有表A和表B
表A 结构   
id      je
11      1
12      2
11     1

表B
id    kf
11   2
11   1

想得到结果为
id    sum(a.je),sum(b.kf),sum(a.je)-sum(b.kj)
11   2              3                 -1

写的语句如下
select a.id,sum(a.je),sum(b.kf),sum(a.je)-sum(b.kj) from A ,B where A.id*=B.id  group by a.id
但得到结果如下:
id    sum(a.je),sum(b.kf),sum(a.je)-sum(b.kj)
11   4              3                 1
相当于把表A的数据汇总了两次,如何用一条语句解决问题????

论坛徽章:
0
2 [报告]
发表于 2010-04-27 19:20 |只看该作者
回复 1# jtyhyl

你用了where a.id=b.id,这样就生成了4条结果:
你可以试试执行select a.id, a.je, b.kf from a,b where a.id=b.id, 可以产生2*2=4条结果:
id          je          kf
-----------------------------------
11          1           1
11          1           2
11          1           1
11          1           2

论坛徽章:
0
3 [报告]
发表于 2010-04-27 19:42 |只看该作者
本帖最后由 xjtuhuth 于 2010-04-28 08:09 编辑

回复 1# jtyhyl


    你试试:
select a.id, a.sum_je, b.sum_kf from (select id, sum(je) as sum_je from 表一 group by id) a join (select id, sum(kf) as sum_kf from 表二 group by id) b on a.id = b.id

论坛徽章:
0
4 [报告]
发表于 2010-04-28 22:07 |只看该作者
3q
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP