Still celebrating National IT Professionals Day with 3 months of free Premium Membership. Use Code ITDAY17

x
Solved

# Calculating the Data in Oracle

Posted on 2011-09-27
Medium Priority
334 Views
I had to calculate varience in oracle. I know there is a function in oracle named varience

I am doing VARIENCE as (MyExpectedData - MyActualReturns)

1. How Does Varience Work...

2. Alo I want to Return data as Percentage for one of the column which is a combination of two columns as:

(Column1/Column2)*100 as myNewData

But this does has errors, if there is a division by zero. It throws an error and second how do i bring its result in percentage sign with it

Thanks
0
[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
• 7
• 4

LVL 16

Expert Comment

ID: 36715069
For getting % symbol you can concatenate with % sign like :

select (((1/1)*100)||'%') percent_data from dual ;

>>> this does has errors, if there is a division by zero.

Can you provide some sample data so that we can check ?
0

LVL 16

Expert Comment

ID: 36715082

0

LVL 16

Author Comment

ID: 36715508
yes!

sample data like this

select
column1, column2,
(column1/column2 * 100) as column3
from my table

So this is how i am getting the data, But please also tell if there is a divison by zero then how we do handle it
0

LVL 16

Expert Comment

ID: 36715655
Please find the example as :

create  temp_t (col1 number , col2 number);

begin
insert into temp_t values (1,1);
insert into temp_t values (1,0);
end;

commit;

Error Query:

SQL> select (((col1/col2)* 100 )||'%') data_percent from temp_t ;

Valid Query:

SQL> select  ((CASE WHEN (NVL(max(col2),0) = 0) THEN 0 ELSE ( col1/col2)* 100 END)||'%') percent
from temp_t
group by col1,col2;
0

LVL 16

Expert Comment

ID: 36715700
you can remove the max from the valid query ......
0

LVL 16

Accepted Solution

Swadhin Ray earned 2000 total points
ID: 36715723
Valid Query:

SQL> select  ((CASE WHEN (NVL(col2,0) = 0) THEN 0 ELSE ( col1/col2)* 100 END)||'%') percent
from temp_t
group by col1,col2;
0

LVL 16

Author Comment

ID: 36716031
why using groupby
0

LVL 16

Author Comment

ID: 36716047
also if omit group it will display correct data rt, also does it handles the decimal places also
0

LVL 16

Expert Comment

ID: 36716057
...you can remove group by  condition...
0

LVL 16

Author Comment

ID: 36716118
also will decilams play good
0

LVL 16

Expert Comment

ID: 36716218
just try it and let us know if you get any issues
0

## Featured Post

Question has a verified solution.

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

A Stored Procedure in Microsoft SQL Server is a powerful feature that it can be used to execute the Data Manipulation Language (DML) or Data Definition Language (DDL). Depending on business requirements, a single Stored Procedure can return differeâ€¦
Instead of error trapping or hard-coding for non-updateable fields when using QODBC, let VBA automatically disable them when forms open. This way, users can view but not change the data. Part 1 explained how to use schema tables to do this. Part 2 hâ€¦
This video shows how to Export data from an Oracle database using the Datapump Export Utility.  The corresponding Datapump Import utility is also discussed and demonstrated.
This video shows how to recover a database from a user managed backup
###### Suggested Courses
Course of the Month7 days, 19 hours left to enroll