jn615
jn615
2010-09-08 09:30

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之类的

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

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享
  • 邀请回答

3条回答

  • icefishc icefishc 11年前
    点赞 评论 复制链接分享
  • zgy52188 zgy52188 11年前

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

    点赞 评论 复制链接分享
  • zgy52188 zgy52188 11年前

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

    点赞 评论 复制链接分享

相关推荐