SqlServer 行列转换

我数据库里有张Employee表:
ID FirstName LastName
1 san zhang
2 si li
3 wu wang

我现在想把行和列转换一下

转换之后就是这样:
ID 1 2 3
FirstName san si wu
LastName zhang li wang

我现在的做法是:
在store prodcedure里面,建立一个tmp table,这个table用dynamic sql来生成columns。有一个employee,就要一个column。如果有1万个employee,就要有1万个columns。
然后再一个一个地往这个tmp table里面填数据

这种做法问题不少,最大的问题就是performance

我想知道有什么更简单的方法。也许根本不需要在store procedure里来做,也许.net sql report自己就能变。
又或者sql 2008里面有什么function能够做到pivot之类的

有谁知道能赐教下吗,万分感谢

都08了当然是pivot了
http://msdn.microsoft.com/en-us/library/ms177410.aspx

sqlserver的行转列 很常见的问题,随便在网上一收就有很多,自己去尝试做。

前人已经有了解决方案,变通一下就可以了呗。看看别人的这样也少走弯路