Solved

Decode and NVL

Posted on 2014-07-18
3
293 Views
Last Modified: 2014-07-21
Hello,

Please assist with understanding the statement below. I understand for example NVL(PE.PAID,0) is stating if pe.paid is null place a zero.

where
 (NVL(DECODE(NVL(PE.OKTOBILL,0),1,DECODE(TO_CHAR(PE.HICFIRST,'YYYY'),'0000', 0, NVL(PE.BILLED,0)),0),0) - NVL(PE.WRITTENOFF,0) - NVL(PE.PAID,0)) >0

Thank you for the help.
0
Comment
Question by:jverasql
3 Comments
 
LVL 76

Assisted Solution

by:slightwv (䄆 Netminder)
slightwv (䄆 Netminder) earned 125 total points
ID: 40205056
decode goes like this:
decode(this_value,when_a,return_a,when_b,return_b,else_return_this)


Break it down and indent it to take each piece individually:
 
 (
 	NVL(
 		DECODE(
			--if the nvl on oktobill = 1 then return the value of the decode
 			NVL(PE.OKTOBILL,0),1,
 			DECODE(
				--If the YYYY = '0000' return 0
 				TO_CHAR(PE.HICFIRST,'YYYY'),'0000', 0,
				--else return this
 				NVL(PE.BILLED,0)
 			),0
 		),0
 	)
 	-
 	NVL(PE.WRITTENOFF,0) - NVL(PE.PAID,0)
 ) >0

Open in new window

0
 
LVL 1

Assisted Solution

by:Pooja Katiyar Verma
Pooja Katiyar Verma earned 125 total points
ID: 40205423
It will return PE.OKTOBILL 0 if it's data value is null or any other value apart from 1, If it is 1 then it will compare value of PE.HICFIRST in second decode used-  if year part i.e. to_Char(HICFIRST,'YYYY') is '0000' it will return 0, if not then it will compare PE.BILLED with PE.HICFIRST if PE.BILLED is null or value of both columns matches it will return 0.

The result of above value return is then compared in where clause: whether it is greater then 0 or not
0
 
LVL 48

Accepted Solution

by:
PortletPaul earned 250 total points
ID: 40206877
perhaps as case expressions will help?
WHERE (
       NVL(
            CASE
                  WHEN NVL(PE.OKTOBILL, 0) = 1 THEN
                        CASE
                              WHEN TO_CHAR(PE.HICFIRST, 'YYYY') = '0000' THEN 0
                              ELSE NVL(PE.BILLED, 0) 
                        END
                  ELSE 0 
            END
        , 0)
      - NVL(PE.WRITTENOFF, 0) - NVL(PE.PAID, 0)
      ) > 0

Open in new window

0

Featured Post

Live: Real-Time Solutions, Start Here

Receive instant 1:1 support from technology experts, using our real-time conversation and whiteboard interface. Your first 5 minutes are always free.

Question has a verified solution.

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

Checking the Alert Log in AWS RDS Oracle can be a pain through their user interface.  I made a script to download the Alert Log, look for errors, and email me the trace files.  In this article I'll describe what I did and share my script.
Entering time in Microsoft Access can be difficult. An input mask often bothers users more than helping them and won't catch all typing errors. This article shows how to create a textbox for 24-hour time input with full validation politely catching …
This video shows setup options and the basic steps and syntax for duplicating (cloning) a database from one instance to another. Examples are given for duplicating to the same machine and to different machines
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

785 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