Discussions
Categories
- 385.5K All Categories
- 4.9K Data
- 2.5K Big Data Appliance
- 2.4K 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
Help with Case When statement

I am trying to compare the "LATEST_EVENT_DT" (date) to the "Greatest Date" (date).
Then for the "Latest Event", display 'CANCELLED' if the "Greatest Date" is greater than the 'LATEST_EVENT_DT" and if not, then display the value in the "LATEST_EVENT_DESC" column.
If I take out the "Latest Event" part everything works fine. But with it in I get the error "FROM keyword not found where expected". Can someone help with this?
select
LATEST_EVENT_DT,
"OIT_Closed_Date", "OIR_Closed_Date", "OIN_Closed_Date",
greatest(LATEST_EVENT_DT, nvl( "OIT_Closed_Date",TO_DATE('01011950', 'MMDDYYYY')), nvl("OIR_Closed_Date",TO_DATE('01011950', 'MMDDYYYY')) ,nvl( "OIN_Closed_Date",TO_DATE('01011950', 'MMDDYYYY'))) "Greatest Date",
"Latest Event" =
CASE
WHEN LATEST_EVENT_DT < "Greatest Date" THEN 'CANCELLED'
ELSE LATEST_EVENT_DESC
END
from apex01.greatest_date_vw_SGD
Thanks,
Steven
Best Answer
-
Hi, Steven,
What is
"Latest Event" =
supposed to do? Do you want the column produced by the CASE expression to appear as "Latest Event" in the output? If so, use a column alias after the expression, like you did with "Greatest Date".
You can't define a column alias (like "Greatest Date") and then reference that alias in the same SELECT clause where it was defined. Derive the column in a sub-query, then you can reference it in a super-query, like this:
WITH got_greatest_date AS ( select LATEST_EVENT_DT , "OIT_Closed_Date" , "OIR_Closed_Date" , "OIN_Closed_Date" , greatest ( LATEST_EVENT_DT , nvl ( "OIT_Closed_Date" , TO_DATE ('01011950', 'MMDDYYYY') ) , nvl ( "OIR_Closed_Date" , TO_DATE ('01011950', 'MMDDYYYY') ) , nvl ( "OIN_Closed_Date" , TO_DATE ('01011950', 'MMDDYYYY') ) ) AS "Greatest Date" from apex01.greatest_date_vw_SGD ) SELECT g.* , CASE WHEN LATEST_EVENT_DT < "Greatest Date" THEN 'CANCELLED' ELSE LATEST_EVENT_DESC END AS "Latest Event" FROM got_greatest_date g ;
Do you really like the double-quoted names? Most people find them very confusing, and much more trouble than they're worth.
Answers
-
Like this?
select LATEST_EVENT_DT, "OIT_Closed_Date", "OIR_Closed_Date", "OIN_Closed_Date", "Greatest Date", CASE WHEN LATEST_EVENT_DT < "Greatest Date" THEN 'CANCELLED' ELSE LATEST_EVENT_DESC END AS "Latest Event" from ( select LATEST_EVENT_DT, "OIT_Closed_Date", "OIR_Closed_Date", "OIN_Closed_Date", greatest(LATEST_EVENT_DT, nvl( "OIT_Closed_Date",TO_DATE('01011950', 'MMDDYYYY')), nvl("OIR_Closed_Date",TO_DATE('01011950', 'MMDDYYYY')) ,nvl( "OIN_Closed_Date",TO_DATE('01011950', 'MMDDYYYY'))) "Greatest Date" from apex01.greatest_date_vw_SGD )
-
Hi, Steven,
What is
"Latest Event" =
supposed to do? Do you want the column produced by the CASE expression to appear as "Latest Event" in the output? If so, use a column alias after the expression, like you did with "Greatest Date".
You can't define a column alias (like "Greatest Date") and then reference that alias in the same SELECT clause where it was defined. Derive the column in a sub-query, then you can reference it in a super-query, like this:
WITH got_greatest_date AS ( select LATEST_EVENT_DT , "OIT_Closed_Date" , "OIR_Closed_Date" , "OIN_Closed_Date" , greatest ( LATEST_EVENT_DT , nvl ( "OIT_Closed_Date" , TO_DATE ('01011950', 'MMDDYYYY') ) , nvl ( "OIR_Closed_Date" , TO_DATE ('01011950', 'MMDDYYYY') ) , nvl ( "OIN_Closed_Date" , TO_DATE ('01011950', 'MMDDYYYY') ) ) AS "Greatest Date" from apex01.greatest_date_vw_SGD ) SELECT g.* , CASE WHEN LATEST_EVENT_DT < "Greatest Date" THEN 'CANCELLED' ELSE LATEST_EVENT_DESC END AS "Latest Event" FROM got_greatest_date g ;
Do you really like the double-quoted names? Most people find them very confusing, and much more trouble than they're worth.
-
Thanks for the quick reply Frank.
Only thing I had to add was "LATEST_EVENT_DESC" into the first select statement.
-
Hi, Steven,
StevenD609 wrote: Thanks for the quick reply Frank. Only thing I had to add was "LATEST_EVENT_DESC" into the first select statement.
Good catch! Since I didn't have a copy of your table, I couldn't test it.