[img]http://dl2.iteye.com/upload/attachment/0086/4670/6b0db358-4f8a-3d25-b7cf-d8c08517d452.jpg[/img]
把你的类型分个类:未续费、已续费
(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
。
。
。
不知道你需要什么查询条件,如果是时间的话可以考虑TO_CHAR(SYSDATE,'yyyymm'),费用应该用sum,按名称分组。
你要查什么信息?表结构呢?
oracle 解析sql的where部分是从后向前解析 看你的sql条件部分最后一个用的是like %,这样恐怕会耗损性能。 建议将容易筛除掉数据的条件放在后边。 其他的不知道你的表结构如何就难以下一步优化了。