Converting rows to Columns in SQL
- by Ram
I have a table (actually a view, but simplified my example to a table) which gives me some data like this
id  CompanyName website
1   Google          google.com
2   Google          google.net
3   Google          google.org
4   Google          google.in
5   Google          google.de
6   Microsoft       Microsoft.com
7   Microsoft       live.com
8   Microsoft       bing.com
9   Microsoft       hotmail.com
I am looking to convert it to get a result like this 
CompanyName website1      website2   website3   website 4   website5  website6 
----------- ------------- ---------- ---------- ----------- --------- --------
Google      google.com    google.net google.org google.in   google.de NULL
Microsoft   Microsoft.com live.com   bing.com   hotmail.com NULL      NULL
I have looked into pivot but looks like the record(row values) cannot be dynamic (i.e can only be certain predefined values). 
Also, if there are more than 6 websites, I want to limit it to the first 6
Dynamic pivot makes sense, but I would have to incorporate it into my view ?? Is there a simpler solution for this ?
Here are the SQL scripts
CREATE TABLE [dbo].[Company](
    [id] [int] NULL,
    [CompanyName] [varchar](50) NULL,
    [website] [varchar](50) NULL
) ON [PRIMARY]
GO
insert into company values (1,'Google','google.com')
insert into company values (2,'Google','google.net')
insert into company values (3,'Google','google.org')
insert into company values (4,'Google','google.in')
insert into company values (5,'Google','google.de')
insert into company values (6,'Microsoft','Microsoft.com')
insert into company values (7,'Microsoft','live.com')
insert into company values (8,'Microsoft','bing.com')
insert into company values (9,'Microsoft','hotmail.com')