设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

返回列表 发新帖
查看: 5557|回复: 5
打印 上一主题 下一主题

[查询] 关于access数据库中的分组统计查询的问题

[复制链接]
跳转到指定楼层
1#
发表于 2007-9-20 11:35:17 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
我在access中开发,想做一个分组统计的报表,源数据如下
姓名 单位 帐号 金额
人1 单位1 aa 50
人1 单位1 bb 60
人1 单位1 bb 100
人1 单位2 cc 30
人1 单位3 dd 200
人2 单位4 ff 60
人2 单位4 gg 700
人2 单位5 hh 8

想得到的结果是按姓名和单位以及金额的范围,统计帐户数和金额总数,如下:
姓名 单位    50以下个数 50以下金额总计  50~100个数 50~100金额总计  100以上个数 100以上金额总计
人1   单位1   0                  0                         3                   210                      0                    0
人1   单位2   1                  30                       0                   0                          0                    0
人1   单位3   0                  0                         0                   0                          1                    200
人2   单位4   0                  0                         1                   60                        1                    700
人2   单位5   1                  8                         0                   0                          0                    0

我想实现的功能在其他数据库里也可以用case when 实现,好像access里有一个iif可以实现类似功能,我写了如下的sql:
"select 姓名,单位,count(iif("金额<50",帐号,0)), sum(iif("金额<50",金额,0)),count(iif("金额>50",帐号,0)), sum(iif("金额>50",金额,0))
from 表名
group by 姓名,单位"

可是结果集中的第4,5字段的值跟2,3字段值一样,而且是不区分金额的所有记录,是不是我的写法有错?
姓名 单位 Expr1002 Expr1003 Expr1004 Expr1005
1       1      3               210         3              210
1       2     1                30           1              30
1       3     1                200         1              200
2       4     2                760         2              760
2       5     1                8             1               8



[ 本帖最后由 testyou 于 2007-9-20 12:05 编辑 ]

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 分享淘帖 订阅订阅
2#
发表于 2007-9-20 11:43:38 | 只看该作者
上传示例,

点击这里给我发消息

3#
发表于 2007-9-20 11:49:08 | 只看该作者

是不是这样子

select 姓名,单位,金额 As 50以下金额总计
from 表名
WHERE 金额<50
group by 姓名,单位
4#
 楼主| 发表于 2007-9-20 11:55:29 | 只看该作者
谢谢楼上的!
不过我要分的组比较多,金额50以下的帐户数统计,金额统计, 金额50~100的帐户数统计,金额统计,金额100以上的帐户数统计,金额统计等等, 需要在一个结果集中显示, 上面的办法行不通.

点击这里给我发消息

5#
发表于 2007-9-20 13:15:52 | 只看该作者
SELECT 表1.姓名, 表1.单位, Sum(IIf([金额]<50,1,0)) AS 50以下个数, Sum(IIf([金额]<50,[金额],0)) AS 50以下金额总计, Sum(IIf([金额]>=50 And [金额]<=100,1,0)) AS [50-100个数], Sum(IIf([金额]>=50 And [金额]<=100,[金额],0)) AS [50-100金额总计], Sum(IIf([金额]>100,1,0)) AS 100以上个数, Sum(IIf([金额]>100,[金额],0)) AS 100以上金额总计 FROM 表1 GROUP BY 表1.姓名, 表1.单位;

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x
6#
 楼主| 发表于 2007-9-20 14:57:58 | 只看该作者
谢谢t小宝.
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2024-9-26 17:42 , Processed in 0.093822 second(s), 31 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表