免费注册 查看新帖 |

Chinaunix

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

请教个SQL语句(这个能用SQL实现吗) [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-12-24 16:18 |只看该作者 |倒序浏览
有一张交易流水表,字段(流水号 卡号  交易日期  交易时间戳 金额)
流水号是主键,一个卡可以有多个交易流水记录,每个流水的时间戳及金额都可能相同

现在要统计交易日期>2009-11-02,每张卡的交易金额累计达到2万金额(>=20000)时,输出要求如下:

1.卡号
2,达到2万金额对应流水的“流水号”
3,达到2万金额对应流水的“交易时间戳”
4、到达2万时刻累计的金额

论坛徽章:
0
2 [报告]
发表于 2009-12-24 17:26 |只看该作者
需要用over子句

SELECT 卡号,流水号,交易时间戳,累计金额
FROM (
         SELECT 卡号,流水号,交易时间戳,
                SUM(金额)OVER(partition by 卡号 order by 交易时间戳) 累计金额,
                SUM(金额)OVER(partition by 卡号 order by 交易时间戳 range between unbounded preceding and 1 preceding) 前一次累计金额
           FROM 流水表
           WHERE 交易日期>'2009-11-02'   ) T
WHERE 累计金额>=20000
  AND ( 前一次累计金额<20000 or 前一次累计金额 IS NULL )

没有调试,运行后可做相关调整。

论坛徽章:
0
3 [报告]
发表于 2009-12-24 21:02 |只看该作者

回复 #2 Germin 的帖子

领教了,谢谢,明天好好测试一下
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP