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
。
。
。本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥40 复杂的限制性的商函数处理
- ¥15 程序不包含适用于入口点的静态Main方法
- ¥15 素材场景中光线烘焙后灯光失效
- ¥15 请教一下各位,为什么我这个没有实现模拟点击
- ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
- ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
- ¥20 有关区间dp的问题求解
- ¥15 多电路系统共用电源的串扰问题
- ¥15 slam rangenet++配置
- ¥15 有没有研究水声通信方面的帮我改俩matlab代码