MS SQL SERVER 如何把多列的值 , 变成一列多行 .

SELECT'小名'ASc1,'小名'ASc2,'小名'ASc3,'小名'ASc4,'小名'ASc5,'小名'ASc6,'小名'ASc8... SELECT '小名' AS c1 ,
'小名' AS c2 ,
'小名' AS c3 ,
'小名' AS c4 ,
'小名' AS c5 ,
'小名' AS c6 ,
'小名' AS c8
展开
 我来答
dong_1984dd
推荐于2016-01-12 · TA获得超过1.1万个赞
知道小有建树答主
回答量:1070
采纳率:100%
帮助的人:229万
展开全部
  1. 行转列,列转行是我们在开发过程中经常碰到的问题

  2. 行转列一般通过CASE WHEN 语句来实现,也可以通过 SQL SERVER 2005 新增的运算符PIVOT来实现。用传统的方法,比较好理解。层次清晰,而且比较习惯。

  3. 但是PIVOT 、UNPIVOT提供的语法比一系列复杂的SELECT...CASE 语句中所指定的语法更简单、更具可读性 .

  4. --行转列的静态方案一:CASE WHEN,兼容sql2000
     select custid,
    3 sum(case when YEAR(orderdate)=2002 then qty end) as [2002],
      sum(case when YEAR(orderdate)=2003 then qty end) as [2003],
      sum(case when YEAR(orderdate)=2004 then qty end) as [2004]
      from orders
      group by custid;

  5.  --行转列的静态方案二:PIVOT,sql2005及以后版本
    select *
     from (select custid,YEAR(orderdate) as years,qty from orders) as ord
    pivot(sum(qty) for years in([2002],[2003],[2004]))as p

shuangping_zou
2011-07-29 · TA获得超过314个赞
知道小有建树答主
回答量:442
采纳率:0%
帮助的人:208万
展开全部
MS SQL SERVER没有这样的函数可以将多列转变为多行。
SELECT '小名' AS c1
union all
select '小名' AS c2
union all
select '小名' AS c3
union all
select '小名' AS c4
union all
select '小名' AS c5
union all
select '小名' AS c6
union all
select '小名' AS c8
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式