基本表:xf_vip(会员信息) , XF_BONUSLEDGER (积分信息)
两表唯一相同列为 XF_VIPCODE(卡号,又叫会员号)
筛选条件
卡号: 至
性别: 男或女或不限
会员等级: XF_GRADE
消费时间段:XF_BONUSLEDGER.XF_TXDATE
出生日期:XF_DOB
办卡日期:XF_JOINTDATE
消费金额:XF_BONUSLEDGER .XF_AMOUNT
积分排名:
积分区间内:
排序 按会员号
题目:依照样例按要求查询出每人的基本信息与积分状况
所求结果样例:

解释:xf_vip表每人只有一条记录,XF_BONUSLEDGER表每人有多条记录。结果样例中最后三列为XF_BONUSLEDGER表字段采用sum,前面的全为xf_vip表字段。积分有正有负,当前积分为按人分组把所有积分加起来,历史积分为只把正数的积分加起来。
现在我只是试验,只用卡号作为筛选,其它条件暂不做,所写sql语句如下:
select a.xf_vipcode,xf_surname,xf_telephone,xf_address1,xf_sex,
xf_dob,xf_jointdate,
SUM(a.xf_bonus) AS 当前积分 ,
SUM(a.xf_amount) AS 购买金额 ,
SUM(t.xf_bonus) AS 历史积分
FROM XF_VIP,XF_BONUSLEDGER a,XF_BONUSLEDGER t
WHERE (a.xf_vipcode BETWEEN '000000004' AND '600010651')
AND t.xf_vipcode = a.xf_vipcode
AND (a.xf_vipcode = xf_vip.xf_vipcode)
AND t.xf_bonus>0
GROUP BY a.xf_vipcode,xf_surname,xf_telephone,xf_address1,xf_sex,
xf_dob,xf_jointdate
ORDER BY a.xf_vipcode ;
执行后能有结果,但经过人工对基本表中的数据进行采样验证,发现所得积分结果比实际大很多,其中有些 当前积分 与 历史积分 是一样的;购买金额没验证,估计也是同样的错误。
求大神解救
附图:基本表字段信息
xf_vip:

XF_BONUSLEDGER:

------解决方案--------------------
我感觉下面这样写,应该能达到你的需求啊:
select a.xf_vipcode,
xf_surname,
xf_telephone,
xf_address1,
xf_sex,
xf_dob,
xf_jointdate,
SUM(a.xf_bonus) AS 当前积分,
SUM(a.xf_amount) AS 购买金额,
SUM(case
when a.xf_bonus > 0 then
a.xf_bonus
else
o
end) AS 历史积分
FROM XF_VIP, XF_BONUSLEDGER a
WHERE a.xf_vipcode BETWEEN '000000004' AND '600010651'