Solved

How to do an Order by Case with Union All

Posted on 2010-11-22
3
514 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
[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
  • Learn & ask questions
  • 2
3 Comments
 
LVL 143

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 143

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

Is Your DevOps Pipeline Leaking?

Is your CI/CD pipeline a hodge-podge of randomly connected tools? You’ve likely got a tool to fix one problem & then a different tool to fix another, resulting in a cluster of tools with overlapping functionality. Learn how to optimize your pipeline with Gartner's recommendations

Question has a verified solution.

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

Suggested Solutions

Title # Comments Views Activity
SSRS Report 2 61
Publishing SSRS Reports to an IIS Server 3 163
SSRS - How do I get a year value to display based on the current month? 8 72
HIghlights of SSIS? 3 45
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, I have heard from my friends that it’s not possible to create Label Printing report using SSRS. I am amazed after hearing this words not possible in SSRS. I googled lot and found that it is possible to some of people know about the Report Bui…
Are you ready to implement Active Directory best practices without reading 300+ pages? You're in luck. In this webinar hosted by Skyport Systems, you gain insight into Microsoft's latest comprehensive guide, with tips on the best and easiest way…

751 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