fei_6666 2013-07-03 14:34
浏览 232
已采纳

oracle 查询统计

  • 写回答

4条回答 默认 最新

  • tearhero 2013-07-04 13:35
    关注

    把你的类型分个类:未续费、已续费
    (1)如果你在where在加未续费的条件(其实就是用日期比较),然后用count合计数量,就会导致一个sql里面只能统计出一种类型(未续费)的数据,其他类型(已续费)的数据就只能用你说的24次查询去查(你的实现方式是funtion)
    (2)可以尝试换一种思路:
    在where中不加限制条件,在查询出来的列中加判断(已续费数量:如果是已续费那么数量就为1,不是已续费数量就为0)+配合聚合函数sum
    (3)sql大概如下(注:一直没看懂你的“只要auth_enddate 该字段的值在某个月份内”,这个“某个月份”指的值哪个字段,就暂且认为12个月份都要统计;A.auth_enddate > '201302'可能要你自己确定规则;search_start_month为你输入查询条件起始时间):
    select '201301',
    sum(case when auth_enddate > 201301 then 1 else 0 end) as 已续费数量,
    sum(case when auth_enddate < 201301 then 1 else 0 end) as 未续费数量
    from A
    where '201301' group by 产品
    union
    select 201302,
    sum(case when auth_enddate > 201302 then 1 else 0 end) as 已续费数量,
    sum(case when auth_enddate < 201302 then 1 else 0 end) as 未续费数量
    from A
    where '201302'<search_start_month
    group by 产品
    union


    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码