sql >> Databasteknik >  >> RDS >> Oracle

SQL trunc/grupp/order efter datum (dag/månad/kvartal/år) med summa hoppa över datum utan data

Prova något i stil med detta (förenklat exempel):

with 
months_int as
(select trunc(min(inc_date), 'MM') min_month, trunc(max(inc_date), 'MM') max_month
 from data),
months as
(
  select add_months(min_month, level-1) mnth_date
  from months_int 
  connect by add_months(min_month, level-1)<= max_month
  )
select  mnth_date, sum(cnt) 
from data  right outer join months on trunc(inc_date, 'MM') = mnth_date
group by mnth_date
order by mnth_date

Här är ett exempel på sqlfiddle



  1. En till en relation i MySQL

  2. Hur man installerar SQLOPS på en Mac

  3. Hur man installerar Lighttpd med PHP, MariaDB och PhpMyAdmin i Ubuntu

  4. Oracle kan inte uppdatera till NULL