views:

81

answers:

5

I want a specific order for the Completion_Status column as in:

Completed, Passed, Incomplete & Failed

How do I do I order this? I want to define the order above.

I tried CASE but it give me an error as in Expecting NUM not CHAR.

select DISTINCT
  u.first_name || ' ' ||  u.last_name  "Employee_Name",
  rco.title "Course_Name",
  decode(p.status,'P','Passed', 'F','Failed', 'C','Completed', 'I','Incomplete', 'Not Attempted') "Completion_Status",

   to_char(p.completed_date,'YYYY-MM-DD') "Date_Completed"
   from
   offering o, offering_enrollment oe, users u ,  performance p, offering_content_object c, content_object rco
  where
  o.id = oe.offering_id  and
  u.id = oe.user_id and
  o.content_object_id = c.id AND
  p.content_object_id = c.source_id and
  p.content_object_id = rco.id AND
  p.user_id(+) = u.id  and
  u.id in ( select id
                  from users
                  where manager_id = $user.id$) 
                  AND
p.content_object_id NOT IN (41453457, 130020319, 43363877)
order by 
"Employee_Name", "Completion_Status"
+3  A: 

Edit: i now assume your base data is the single char...

order by decode(p.status,'P',1,'F',2,'C',3,'I',4) 
Randy
+6  A: 

You may be able to use something like:

ORDER BY "Employee_Name", CASE "Completed_Status"
                          WHEN 'Completed'  THEN 0
                          WHEN 'Passed'     THEN 1
                          WHEN 'Incomplete' THEN 2
                          WHEN 'Failed'     THEN 3
                          ELSE                   4
                          END;

You might need to change the CASE to work on the raw 'p.status' value, in which case the WHEN conditions change too:

ORDER BY "Employee_Name", CASE p.status
                          WHEN 'C' THEN 0
                          WHEN 'P' THEN 1
                          WHEN 'I' THEN 2
                          WHEN 'F' THEN 3
                          ELSE          4
                          END;
Jonathan Leffler
+1: 9i was the first version to support CASE. Prior to 9i, it'd have to be `DECODE`...
OMG Ponies
+2  A: 

You have to provide the order yourself in your case statement:

SELECT ...
ORDER BY Employee_Name,
    (CASE WHEN Completion_Status = 'Completed' THEN 0
          WHEN Completion_Status = 'Passed' THEN 1
          WHEN Completion_Status = 'Incomplete' THEN 2
          WHEN Completion_Status = 'Failed' THEN 3
          ELSE 4
     END)
Daniel Vandersluis
+2  A: 

Can you add a new line to SELECT:

decode(p.status,'P',2, 'F',4, 'C',1, 'I',3, 5) "Completion_Status Level",

and then ORDER BY it?

eumiro
A: 

Thank you all for your replies:

The following worked like a charm!

ORDER BY "Employee_Name", CASE "Completed_Status" 
                          WHEN 'Completed'  THEN 0 
                          WHEN 'Passed'     THEN 1 
                          WHEN 'Incomplete' THEN 2 
                          WHEN 'Failed'     THEN 3 
                          ELSE                   4 
                          END; 
SQL-LB
Nice that it worked. Perhaps you could accept one of the answers?
Bob Jarvis