Solved

How can I display repeating feilds horizontal using pivot

Posted on 2010-08-23
5
301 Views
Last Modified: 2012-05-10
I have this data

ID      Name      Code      Type
1      Sam      205      office
2      Sam      778      home
3      Sam      678      cell
4      Bob      789      office
5      Bob      167      home
6      Tim      556      cell

I want to create a view that will display the data this way

Name      Code1      Type1      Code2      Type2      Code3      Type3
Sam        205         office         778         home          678         cell
Bob        789         office         167         home
Tim                                                                              556         cell


How can I do this using pivot in SQL Server 2005
0
Comment
Question by:vraj20
  • 3
  • 2
5 Comments
 
LVL 41

Expert Comment

by:ralmada
ID: 33503865
try the below:

DECLARE @strSQL varchar(8000) 

DECLARE @COLS VARCHAR(8000) 





SELECT @COLS = 	coalesce(@COLS+',', '') + 

		'max(case when [rn] = ' + rn + ' then [Code] end) as [Code' + cast(rn as varchar) + ']' 

		', max(case when [rn] = ' + rn + ' then [Type] end) as [Type' + cast(rn as varchar) + ']' 



from (

	select distinct row_number() over (partition by Name order by ID) rn from yourtable

) a 



set @strSQL = 'select 	Name, ' + @cols + ' from (select *, row_number() over (partition by Name order by ID) rn from yourtable ) t1 group by Name'



exec(@strSQL)

Open in new window

0
 

Author Comment

by:vraj20
ID: 33505352
'max(case when [rn] = ' + rn + ' then [Code] end) as [Code' + cast(rn as varchar) + ']'

What does rn represent?
0
 
LVL 41

Expert Comment

by:ralmada
ID: 33505418
rn is just a column that I'm creating using the row_number() function to number code and types column like code1, code2, etc....
 
Hope this helps
0
 

Author Comment

by:vraj20
ID: 33511530
Thank you for your assistance. When I run your script I get these error message

Msg 102, Level 15, State 1, Line 7
Incorrect syntax near ', max(case when [rn] = '.
Msg 102, Level 15, State 1, Line 11
Incorrect syntax near 'a'.
0
 
LVL 41

Accepted Solution

by:
ralmada earned 500 total points
ID: 33512072
yep, need a cast there and missed a plus sign.
DECLARE @strSQL varchar(8000) 

DECLARE @COLS VARCHAR(8000) 





SELECT @COLS = 	coalesce(@COLS+',', '') + 

		'max(case when [rn] = ' + rn + ' then [Code] end) as [Code' + cast(rn as varchar) + ']' +

		', max(case when [rn] = ' + rn + ' then [Type] end) as [Type' + cast(rn as varchar) + ']' 



from (

	select distinct cast(row_number() over (partition by Name order by ID) as varchar) rn from yourtable

) a 



set @strSQL = 'select 	Name, ' + @cols + ' from (select *, row_number() over (partition by Name order by ID) rn from yourtable ) t1 group by Name'



exec(@strSQL)

Open in new window

0

Featured Post

6 Surprising Benefits of Threat Intelligence

All sorts of threat intelligence is available on the web. Intelligence you can learn from, and use to anticipate and prepare for future attacks.

Join & Write a Comment

Suggested Solutions

So every once in a while at work I am asked to export data from one table and insert it into another on a different server.  I hate doing this.  There's so many different tables and data types.  Some column data needs quoted and some doesn't.  What …
In this article I will describe the Copy Database Wizard method as one possible migration process and I will add the extra tasks needed for an upgrade when and where is applied so it will cover all.
This video demonstrates how to create an example email signature rule for a department in a company using CodeTwo Exchange Rules. The signature will be inserted beneath users' latest emails in conversations and will be displayed in users' Sent Items…
This video explains how to create simple products associated to Magento configurable product and offers fast way of their generation with Store Manager for Magento tool.

747 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

10 Experts available now in Live!

Get 1:1 Help Now