Discussions
Categories
- 385.5K All Categories
- 5.1K Data
- 2.5K Big Data Appliance
- 2.5K Data Science
- 453.4K Databases
- 223.2K General Database Discussions
- 3.8K Java and JavaScript in the Database
- 47 Multilingual Engine
- 606 MySQL Community Space
- 486 NoSQL Database
- 7.9K Oracle Database Express Edition (XE)
- 3.2K ORDS, SODA & JSON in the Database
- 585 SQLcl
- 4K SQL Developer Data Modeler
- 188K SQL & PL/SQL
- 21.5K SQL Developer
- 46 Data Integration
- 46 GoldenGate
- 298.4K Development
- 4 Application Development
- 20 Developer Projects
- 166 Programming Languages
- 295K Development Tools
- 150 DevOps
- 3.1K QA/Testing
- 646.7K Java
- 37 Java Learning Subscription
- 37.1K Database Connectivity
- 201 Java Community Process
- 108 Java 25
- 22.2K Java APIs
- 138.3K Java Development Tools
- 165.4K Java EE (Java Enterprise Edition)
- 22 Java Essentials
- 176 Java 8 Questions
- 86K Java Programming
- 82 Java Puzzle Ball
- 65.1K New To Java
- 1.7K Training / Learning / Certification
- 13.8K Java HotSpot Virtual Machine
- 94.3K Java SE
- 13.8K Java Security
- 208 Java User Groups
- 25 JavaScript - Nashorn
- Programs
- 667 LiveLabs
- 41 Workshops
- 10.3K Software
- 6.7K Berkeley DB Family
- 3.6K JHeadstart
- 6K Other Languages
- 2.3K Chinese
- 207 Deutsche Oracle Community
- 1.1K Español
- 1.9K Japanese
- 474 Portuguese
Query returning empty months

Hi all,
I have this query that returns the production of the last 12 months.
This is the query:
select null , sum(f.comision) value , trunc(f.efectiva, 'MM') label from risk_facturas f where f.efectiva >= add_months(trunc(sysdate), -13) and f.efectiva < trunc(sysdate) + 1 and f.organizacion_id = :APP_GET_ORGANIZACION_ID group by trunc(f.efectiva, 'MM')
How can I get a line for every month no matter if it has any production or is just 0? Can this be done?
Thanks for the help!
Javier
Best Answer
-
@Javier P: I mean five years back from the end of the current year.
with t as ( select 0 comision, add_months(trunc(sysdate,'yy'),(1-level) * 12) efectiva from dual connect by level <= 5 union all select comision, trunc(efectiva,'yy') from risk_facturas where fefectiva >= add_months(trunc(sysdate,'yy'),-48) and efectiva < add_months(trunc(sysdate,'yy'),12) and organizacion_id = :APP_GET_ORGANIZACION_ID ) select null NullValue, sum(comision) value, efectiva label from t group by efectiva order by efectiva /
SY.
Answers
-
select * from (your query) t right join (select trunc(add_months(sysdate,1-level),'mm') d from dual connect by level<14) u on u.d = t.label
-
Thanks User_H3J7U
What do mean with your query?
The full select statement?
select * from (select null , sum(f.comision) value , trunc(f.efectiva, 'MM') label from risk_facturas f where f.efectiva >= add_months(trunc(sysdate), -13) and f.efectiva < trunc(sysdate) + 1 and f.organizacion_id = :APP_GET_ORGANIZACION_ID group by trunc(f.efectiva, 'MM')) t right join (select trunc(add_months(sysdate,1-level),'mm') d from dual connect by level<14) u on u.d = t.label
Like this?
Thanks again!
-
Hi,
Am getting this error:
Thanks,
-
Replace "f.label" with:
trunc(f.efectiva, 'MM')
Label does not exist as a column on the risk_facturas table, it is just an alias and cannot be used in the same query except on the ORDER BY clause. Or you can use it on a higher level (parent) query, like this:
select * from ( select null AS NullValue , sum(f.comision) AS value , trunc(f.efectiva, 'MM') AS label from risk_facturas f where f.efectiva >= add_months(trunc(sysdate), -13) and f.efectiva < trunc(sysdate) + 1 and f.organizacion_id = :APP_GET_ORGANIZACION_ID group by trunc(f.efectiva, 'MM') ) oq right join (select trunc(add_months(sysdate,1-level),'mm') d from dual connect by level<14) u on u.d = oq.label
-
Hi Fernigrini,
Thanks for your help!
I will try it that way.
Thanks
-
with t as ( select 0 comision, trunc(add_months(sysdate,1-level),'mm') efectiva from dual connect by level < 14 union all select comision, trunc(efectiva,'MM') from risk_facturas where fefectiva >= add_months(trunc(sysdate),-13) and efectiva < trunc(sysdate) + 1 and organizacion_id = :APP_GET_ORGANIZACION_ID ) select null NullValue, sum(comision) value, efectiva label from t group by efectiva order by efectiva /
SY.
-- correction: f. is removed
-
Hi SY
Thanks for the complete code and your help.
I appreciate it.
-
Hi Sy
Can you help me with the same query but returning the last 5 year and grouping by year?
I need the query group by year and returning all last 5 years no matter if it has any production
Return 0 If it does not have any production for that year.
Thanks a lot for your help!
-
In this case it is simple enough to use the APEX chart settings to handle the data densification automatically.
-
Hi fac586,
Yes, that is what I figured and am using the setting you mentioned to me but having other problems that I posted in the same thread.
Thanks always for you help!