Solved

record selection

Posted on 2008-10-23
5
191 Views
Last Modified: 2012-05-05
is there a way to extract multiple records into 1 record
i am trying the listed statement
select saletype, classDesc, selectyear,
case when yearnumber = 1 then prem_amt end as Year1,
case when yearnumber = 2 then prem_amt end as Year2,    
case when yearnumber = 3 then prem_amt end as Year3,
case when yearnumber = 4 then prem_amt end as Year4
from qClassDescSummaryReport
group by saletype, classDesc, selectyear

it gives me two error messages
Column 'qClassDescSummaryReport.prem_amt' is invalid in the select list because it is not contained in either an aggregate function or the GROUP BY clause.

Column 'qClassDescSummaryReport.YearNumber' is invalid in the select list because it is not contained in either an aggregate function or the GROUP BY clause.

is there a way to use pseudo names  for these missing columns




0
Comment
Question by:ldcray
[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
5 Comments
 
LVL 39

Accepted Solution

by:
BrandonGalderisi earned 250 total points
ID: 22790557
You're not attempting any aggregation.... if you're trying to do sums, try something like this.
select saletype, classDesc, selectyear, sum(year1), sum(year2), sum(year3), sum(year4)
from 
(select saletype, classDesc, selectyear,
case when yearnumber = 1 then prem_amt else 0 end as Year1,
case when yearnumber = 2 then prem_amt else 0 end as Year2,    
case when yearnumber = 3 then prem_amt else 0 end as Year3,
case when yearnumber = 4 then prem_amt else 0 end as Year4
from qClassDescSummaryReport
) a
group by saletype, classDesc, selectyear

Open in new window

0
 
LVL 23

Assisted Solution

by:adathelad
adathelad earned 250 total points
ID: 22790651
You should even be able to do it in one select, without the nested query:

select saletype, classDesc, selectyear,
sum(case when yearnumber = 1 then prem_amt else 0 end) as Year1,
sum(case when yearnumber = 2 then prem_amt else 0 end) as Year2,    
sum(case when yearnumber = 3 then prem_amt else 0 end) as Year3,
sum(case when yearnumber = 4 then prem_amt else 0 end) as Year4
from qClassDescSummaryReport
group by saletype, classDesc, selectyear
0
 
LVL 39

Expert Comment

by:BrandonGalderisi
ID: 22790707
Absolutely.  That is another completely valid way to do that.  I have found that it's sometimes easier to express in different ways so thanks.
0

Featured Post

Ransomware: The New Cyber Threat & How to Stop It

This infographic explains ransomware, type of malware that blocks access to your files or your systems and holds them hostage until a ransom is paid. It also examines the different types of ransomware and explains what you can do to thwart this sinister online threat.  

Question has a verified solution.

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

I'm trying, I really am. But I've seen so many wrong approaches involving date(time) boundaries I despair about my inability to explain it. I've seen quite a few recently that define a non-leap year as 364 days, or 366 days and the list goes on. …
This post looks at MongoDB and MySQL, and covers high-level MongoDB strengths, weaknesses, features, and uses from the perspective of an SQL user.
Using examples as well as descriptions, and references to Books Online, show the documentation available for date manipulation functions and by using a select few of these functions, show how date based data can be manipulated with these functions.
Via a live example combined with referencing Books Online, show some of the information that can be extracted from the Catalog Views in SQL Server.

717 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