SQL Server 如何实现行转列

 时间:2024-10-25 17:50:17

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

SQL Server 如何实现行转列

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

SQL Server 如何实现行转列

3、使用 CASE WHEN 实现使用 CASE WHEN 语句进行遍历判断,可以很方便的将列值转换成列名。但是,如果需要转换的列值过多,那SQL语句就会变得比较冗余,因此 CASE WHEN 适合列值较少的情况。

SQL Server 如何实现行转列

4、PIVOT 关系运算符介绍PIVOT 的基本语法是对列进行聚合,指定要成为列名的列值以及具体列名。这里要聚合的是“分数”,要指定的是“课程”,具体列名是“美术、音乐、绘画”

SQL Server 如何实现行转列

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

SQL Server 如何实现行转列

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

SQL Server 如何实现行转列
  • 深圳《保险销售从业人员资格证书》考试报名流程
  • 怎么修改汇联易账号密码
  • vb隐藏函数公式
  • sql查询中如何使用连接字符
  • Oracle 11g安装到最后报错闪退
  • 热门搜索
    怎么关闭淘宝店铺 粉刺怎么去除小妙招 山东大学怎么样 上下联怎么区分 鼻屎怎么清理 急需用钱怎么办 微信怎么拍人 烙饼怎么和面 月经肚子疼怎么办 .lnk文件怎么打开