Solved

How to do an Order by Case with Union All

Posted on 2010-11-22
3
487 Views
Last Modified: 2012-05-10
Hello,

I am trying to do an Order by Case on a Select with a UNION ALL. I am getting the error: sql order by items must appear in the select list if the statement contains a union.

I have tried using the order by in both select statements, and have also tried parenthaszing both select statements and placing the order by at the end outside of the parenthesis, but to no avail.

Could someone please take a look at the attachment and let me know what I'm doing wrong? Thanks!
Order-by-case-with-union-all.doc
0
Comment
Question by:erp1022
  • 2
3 Comments
 
LVL 142

Expert Comment

by:Guy Hengel [angelIII / a3]
ID: 34189079
this will do:
SELECT *

 FROM (SELECT a.account as Natural

,rtrim(a.ACTDESCR) as Descr

,(g.CRDTAMNT - g.DEBITAMT) AS Amount

,CASE

WHEN a.account like '400%' then 'G'

WHEN a.account like '42%' or a.accountlike '43%' then 'H'

WHEN a.account = '47100' then '3'

WHEN a.ACCOUNT IN ('45100', '45050') then 'P' 

END as Service



FROM GL00100 a 

INNER JOIN GL20000 g 

ON a.ACTINDX = g.ACTINDX 

INNER JOIN RM00101 c 

ON g.ORMSTRID = c.CUSTNMBR



WHERE a.ACCOUNT LIKE '4%' AND

etc.





UNION ALL



SELECT a.account as Natural

,rtrim(a.ACTDESCR) as Descr

,(g.CRDTAMNT - g.DEBITAMT) AS Amount

,CASE

WHEN a.account like '400%' then 'G'

WHEN a.account like '42%' or a.account like '43%' then 'H'

WHEN a.account = '47100' then '3'

WHEN a.ACCOUNT IN ('45100', '45050') then ‘P’ 

END as Service



FROM GL00100 a 

INNER JOIN GL30000 g 

ON a.ACTINDX = g.ACTINDX 

INNER JOIN RM00101 c 

ON g.ORMSTRID = c.CUSTNMBR



WHERE  a.ACCOUNTLIKE '4%' AND 

) sq



Order by CASE

	WHEN Natural like '400%' then 1

	WHEN Natural like '42%' or Natural like '43%' then 2

	WHEN Natural = '47100' then 3

	WHEN Natural IN ('45100', '45050') then 4

END

Open in new window

0
 

Author Comment

by:erp1022
ID: 34190390
Great, that works! Could you explain what you did and why? I have a couple of other queries I need to modify and would like to understand what I was doing wrong.
0
 
LVL 142

Accepted Solution

by:
Guy Hengel [angelIII / a3] earned 500 total points
ID: 34194610
no problem.

you had (abstract):
select a.field ... from table a UNION select ... ORDER BY a.field 

Open in new window

the issue is that, because you have a union, the ORDER BY cannot know the 2 SELECT field names, because the second query could have completely other tables, aliases, fields ...

so, you have to ORDER BY the resulting field names, so for a.Account as Natural, Natural being the resulting field name, you have to order by that "name" .

CHeers
0

Featured Post

IT, Stop Being Called Into Every Meeting

Highfive is so simple that setting up every meeting room takes just minutes and every employee will be able to start or join a call from any room with ease. Never be called into a meeting just to get it started again. This is how video conferencing should work!

Join & Write a Comment

Introduction: This article is aimed at report developers who are used to developing reports using relational databases and have gotten a first-time assignment to develop reports on OLAP cubes. It demonstrates how to build a report using SQL Ser…
Hi All, I am here to write a simple article to move SSRS (SQL Server Reporting Services) reports from one server to another. When I have faced the same issue to move reports those were developed by developer on development server and now need to …
In this tutorial you'll learn about bandwidth monitoring with flows and packet sniffing with our network monitoring solution PRTG Network Monitor (https://www.paessler.com/prtg). If you're interested in additional methods for monitoring bandwidt…
When you create an app prototype with Adobe XD, you can insert system screens -- sharing or Control Center, for example -- with just a few clicks. This video shows you how. You can take the full course on Experts Exchange at http://bit.ly/XDcourse.

743 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

Need Help in Real-Time?

Connect with top rated Experts

11 Experts available now in Live!

Get 1:1 Help Now