时间:2016-04-03 19:28 来源: 我爱IT技术网 作者:佚名
在sql处理数据的过程中,我们经常会遇到需要把行数据转换成列的问题,同样,列转成行也不少见,那我们在sql应该如何来处理呢?
前期准备工作(包括相关工具或所使用的原料等)
sql server 2008详细的操作方法或具体步骤
首先我们建立一张表,名为RToC,各个字段的设计如下图,分别是name,course,score,表示姓名,成绩与分数,如图所示。

我们往表中加入数据,分别添加小明与小花的语文和数学成绩,如图所示。

接下来,我们要进行行列转换,列应该是name,语文,数学。我们首先要考虑是如何得到列名,我们可以通过分组得到课程名称。如图所示,我们通过分组语句,从查询结果我们可以看出课程名的拼接字符串。

接下来,关键的行转列的函数pivot出场了,通过这个函数我们把分数填充到转换的列语文、数学的列值。

我们运行后,可以得到行转列的结果,如下图所示。

通过以上几个步骤,我们就可以轻松的实现行列转换了。同样,我们如果要把列转换成行, 应该怎么做呢?同样我们可以采用unpivot函数轻松实现。
经验内容仅供参考,如果您需解决具体问题(尤其法律、医学等领域),建议您详细咨询相关领域专业人士。作者声明:本教程系本人依照真实经历原创,未经许可,谢绝转载。- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
