[Last Call] Learn about multicloud storage options and how to improve your company's cloud strategy. Register Now

x
?
Solved

stored procedure rows to columns

Posted on 2013-01-09
11
Medium Priority
?
41 Views
Last Modified: 2016-01-28
i have a table looks like that (notes, actually i have more columns, but it is a simplified version)

1  A  10
1  B  3
2  A  9
2  C  40

How can i convert them to
     A    B    C
1  10   3
2  9         40
0
Comment
Question by:hongclub
[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
  • 4
  • 2
  • 2
  • +1
11 Comments
 
LVL 74

Accepted Solution

by:
sdstuber earned 2000 total points
ID: 38760041
SELECT   col1,
         MAX(CASE WHEN col2 = 'A' THEN col3 END) a,
         MAX(CASE WHEN col2 = 'B' THEN col3 END) b,
         MAX(CASE WHEN col2 = 'C' THEN col3 END) c
    FROM yourtable
GROUP BY col1
ORDER BY col1;
0
 
LVL 12

Expert Comment

by:Jared_S
ID: 38760477
Depending on the amount of data you have, you may want to use a pivot command.

The syntax will be similar to:

select * from (
select col1, col2, col3 from mytable)
a
pivot (max(col3) for col2 in ([A],[B],[C])) as b

Open in new window

0
 

Author Comment

by:hongclub
ID: 38760986
now i twist my data a little bit better and put them into a temp table

How can i make this result set (#result):
A    B     C        dD          dE            dF              dG
test test  test  01/05/2006
test test  test              01/06/2006
test test  test                           01/08/2006
test test  test                                       01/09/2006
test2 test2 test2 06/05/2013
test2 test2 test2             06/06/2013
test2 test2 test2                          06/08/2013
test2 test2 test2                                          06/09/2013  


to

A     B     C                 dD                    dE                     dF                     dG
test  test  test               01/05/2006      01/06/2006      01/08/2006      01/09/2006
test2 test2 test2        06/05/2013      06/06/2013      06/08/2013      06/09/2013


(notes: dD, dE .... are dynamic, but consider it as statis first to make it easier)
0
What does it mean to be "Always On"?

Is your cloud always on? With an Always On cloud you won't have to worry about downtime for maintenance or software application code updates, ensuring that your bottom line isn't affected.

 

Author Comment

by:hongclub
ID: 38760991
you think i should do a left join the table itself?
0
 
LVL 74

Expert Comment

by:sdstuber
ID: 38761034
>>> (notes: dD, dE .... are dynamic, but consider it as statis first to make it easier)

you can't have dynamic columns in SQL.

every column must be known at the time the statement is parsed, not after it executes
0
 
LVL 74

Assisted Solution

by:sdstuber
sdstuber earned 2000 total points
ID: 38761058
no, a left join won't really help

but, using your data above, same idea as before, except it's easier because your data is already nulled and spread as needed to make the aggregation work

SELECT   a,b,c,
         MAX(dd) dd,
         MAX(de) de,
         MAX(df) df,
         max(dg) dg
    FROM yourtable
GROUP BY a,b,c
ORDER BY a,b,c;
0
 
LVL 71

Expert Comment

by:Qlemo
ID: 41428570
I've requested that this question be deleted for the following reason:

Not enough information to confirm an answer.
0
 
LVL 74

Expert Comment

by:sdstuber
ID: 41428562
both of the queries I posted above produces the results requested from the data provided

ID: 38760041 -- for the original data and results
ID: 38761058  -- for the extended data and new results
0
 
LVL 71

Expert Comment

by:Qlemo
ID: 41428571
The dynamic column part is what might be needed, hence my suggestion. But on the other hand, you answered the original question plus addition ... I'll change my suggestion.
0

Featured Post

Concerto's Cloud Advisory Services

Want to avoid the missteps to gaining all the benefits of the cloud? Learn more about the different assessment options from our Cloud Advisory team.

Question has a verified solution.

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

In database programming, custom sort order seems to be necessary quite often, at least in my experience and time here at EE. Within the realm of custom sorting is the sorting of numbers and text independently (i.e., treating the numbers as number…
If you find yourself in this situation “I have used SELECT DISTINCT but I’m getting duplicates” then I'm sorry to say you are using the wrong SQL technique as it only does one thing which is: produces whole rows that are unique. If the results you a…
In this video you will find out how to export Office 365 mailboxes using the built in eDiscovery tool. Bear in mind that although this method might be useful in some cases, using PST files as Office 365 backup is troublesome in a long run (more on t…
Are you ready to place your question in front of subject-matter experts for more timely responses? With the release of Priority Question, Premium Members, Team Accounts and Qualified Experts can now identify the emergent level of their issue, signal…
Suggested Courses

650 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