广告合作
  • 今日头条

    今日头条

  • 百度一下

    百度一下,你就知道

  • 新浪网

    新浪网 - 提供新闻线索,重大新闻爆料

  • 搜狐

    搜狐

  • 豆瓣

    豆瓣

  • 百度贴吧

    百度贴吧——全球领先的中文社区

  • 首页 尚未审核订阅工具 订阅

    SQL Server 如何实现行转列

    来源:网络收集  点击:  时间:2024-02-24
    【导读】:
    在 SQL Server 的日常使用中,做数据统计或报表时,需要将列的值旋转为列名进行呈现。下面介绍在 SQL Server 中实现行转列的方法。工具/原料moreSQL Server 2017SQL Server Management Studio方法/步骤1/6分步阅读

    1、创建临时表

    创建一张临时表#TMP,保存学生课程的分数,并插入一些测试数据。

    2/6

    2、要实现的效果

    将列“课程”的值作为列名呈现,相当于汇聚同一个学生的所有成绩作为一行记录。

    3/6

    3、使用 CASE WHEN 实现

    使用 CASE WHEN 语句进行遍历判断,可以很方便的将列值转换成列名。

    但是,如果需要转换的列值过多,那SQL语句就会变得比较冗余,因此 CASE WHEN 适合列值较少的情况。

    4/6

    4、PIVOT 关系运算符介绍

    PIVOT 的基本语法是对列进行聚合,指定要成为列名的列值以及具体列名。

    这里要聚合的是“分数”,要指定的是“课程”,具体列名是“美术、音乐、绘画”

    5/6

    5、用 PIVOT 实现

    将临时表的实际值填入PIVOT 的基本语法中,即可实现行转列。

    6/6

    6、两者比较

    仔细比较 CASE WHEN 和 PIVOT,可以发现两者在一定程度上其实是一一对应关系,只是 PIVOT 的写法更加简洁和实用,同时理解和写法也更复杂一些。

    本文关键词:

    版权声明:

    1、本文系转载,版权归原作者所有,旨在传递信息,不代表看本站的观点和立场。

    2、本站仅提供信息发布平台,不承担相关法律责任。

    3、若侵犯您的版权或隐私,请联系本站管理员删除。

    4、文章链接:http://www.1haoku.cn/art_143225.html

    相关资讯

    ©2019-2020 http://www.1haoku.cn/ 国ICP备20009186号05-05 03:51:47  耗时:0.028
    0.0281s