Solved

Group wise total of Block in oracle form

Posted on 2014-01-01
10
918 Views
Last Modified: 2014-01-02
i have a block with these column
Code: [Select all] [Show/ hide]

srno,    fin-year     Ename     All_Amount        C_amount
1        2012-2013     A                  50                10
2        2012-2013     B                  30                10
3        2012-2013     C                  10                20
=========================================================
Total                             90                40
============================================================
srno,    fin-year     Ename     All_Amount        C_amount
1        2013-2014     d              20                  5
2        2013-2014     F              30                 10
========================================================
                                 50                 15


i want to total block fin_year wise as i mention above how i can handled in block.
how i can add summary?


Thanks in Advance
Hina mansoor
0
Comment
Question by:hinamansoor
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 5
  • 5
10 Comments
 
LVL 20

Accepted Solution

by:
flow01 earned 500 total points
ID: 39749703
I don't know how to interrupt the lines of a block with something else.
So my solution would be to get the results without oracle forms knowing it's a detail or summery line
If it's a read only block I suggest to  create a view that to gives you the results.
If it's an already existing block change the name of the table to the name of the view
and the format of the srno to varchar2

It could be a view like
create or replace yourview
as
select * from
(
select  to_char(srno) srno,    fin_year,     Ename,     All_Amount,        C_amount
from yourtable
union
select 'Total' , fin_year,  null, sum(All_Amount) , sum(c_amount)
from yourtable
group by fin_year
)
order by fin_year
, case srno
  when 'Total' then 1
  else 0
  end
/
What database version you are using?
0
 

Author Comment

by:hinamansoor
ID: 39749752
Sir database version is oracle database 10.1.0 i tried your above code its giving me error

ERROR at line 1:
ORA-00922: missing or invalid option



Thanks
Hina mansoor
0
 
LVL 20

Expert Comment

by:flow01
ID: 39750034
Sorry , I did only test the select itself
change

create or replace yourview
by
create or replace view yourview
0
Independent Software Vendors: We Want Your Opinion

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

 

Author Comment

by:hinamansoor
ID: 39750109
Sir view is create and i called it also on canvas but there is no group total simple data is showing as we normally table called on canvas. attaching result picture. Sir what would be the next step after called view on canvas.



Thanks
Hina mansoor
result-picture.PNG
0
 
LVL 20

Expert Comment

by:flow01
ID: 39750250
Do it again (calling on canvas)  (i assume you use the wizard)  choose layout style tabular in stead of form (that results in all columns of a row on 1 line) and choose records displayed at 15 or 20 so there will be more then 1 row visible on the screen.

Otherwise use the layour editor to place the columns on a row and change the block-property 'number of records displayed' to the value you want.
0
 

Author Comment

by:hinamansoor
ID: 39750301
Yes it working fine for current year it showing me a TOTAL my question is to you Sir if i would put some more data for 2013-2014 it will give me TOTAL  under the 2012-2013 TOTAL or not. Attaching snap.


Once again Thank you very for helping me a lot.


Thanks
Hina mansoor
result-total.PNG
0
 
LVL 20

Expert Comment

by:flow01
ID: 39750312
Yes , because of the order by in the query.
This is the way i tested it: (based on your example  data)

with yourtable
as
(
select 1 srno,       '2012-2013' fin_year,     'A' ename     ,             50 all_amount,               10  c_amount from dual union
select 2 srno,       '2012-2013' fin_year,     'B' ename     ,             30 all_amount,               10  c_amount from dual union
select 3 srno,       '2012-2013' fin_year,     'C' ename     ,             10 all_amount,               20  c_amount from dual union
select 1 srno,       '2013-2014' fin_year,     'd' ename     ,         20     all_amount,             5     c_amount from dual union
select 2 srno,       '2013-2014' fin_year,     'F' ename     ,         30     all_amount,            10     c_amount from dual
)
select * from
(
select  to_char(srno) srno,    fin_year,     Ename,     All_Amount,        C_amount
from yourtable
union
select 'Total' , fin_year,  null, sum(All_Amount) , sum(c_amount)
from yourtable
group by fin_year
)
order by fin_year
, case srno
  when 'Total' then 1
  else 0
  end
/
0
 

Author Comment

by:hinamansoor
ID: 39750906
gr8 logic Sir how would i implement this code in oracle form in tabular



Thanks
0
 
LVL 20

Expert Comment

by:flow01
ID: 39751856
You don't have to. You have already created the form using  the view.
To test 2013-2014  either  add the records of 2013-2014 in your test database.
Or replace the view you already made with the testquery

create or replace view yourview as
with ... (same code as testquery)
0
 

Author Comment

by:hinamansoor
ID: 39751971
Sir you are really gr8, it worked Thanks you very much Sir




Thanks
Hina mansoor
0

Featured Post

On Demand Webinar - Networking for the Cloud Era

This webinar discusses:
-Common barriers companies experience when moving to the cloud
-How SD-WAN changes the way we look at networks
-Best practices customers should employ moving forward with cloud migration
-What happens behind the scenes of SteelConnect’s one-click button

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
Oracle SQL Select unique values from two columns 4 81
Select and Insert Query running slow 4 58
Password_rules_securitty.. 12 35
SQL query to select row with MAX date 7 41
Have you ever had to make fundamental changes to a table in Oracle, but haven't been able to get any downtime?  I'm talking things like: * Dropping columns * Shrinking allocated space * Removing chained blocks and restoring the PCTFREE * Re-or…
Background In several of the companies I have worked for, I noticed that corporate reporting is off loaded from the production database and done mainly on a clone database which needs to be kept up to date daily by various means, be it a logical…
This videos aims to give the viewer a basic demonstration of how a user can query current session information by using the SYS_CONTEXT function
This video shows how to recover a database from a user managed backup

726 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question