主页 > 知识库 > SQL知识点之列转行Unpivot函数

SQL知识点之列转行Unpivot函数

热门标签:河北便宜电销机器人软件 怎么申请400热线电话 湖南保险智能外呼系统产品介绍 泗洪正规电话机器人找哪家 怎么去开发一个电销机器人 小程序智能电话机器人 简单的智能语音电销机器人 ai电话电话机器人 南昌呼叫中心外呼系统哪家好

前言

这是总结SQL知识点的第二篇文章,一次只总结一个知识点,尽量说明白。上次我们谈到行转列,用的是Pivot函数,这次我们来谈谈Unpivot函数。(这里是用的数据库是SQLSERVER,与其他数据库是类似的,大家放心看就好)

先看一个小问题CustomerCustomer

在这张图中,表示的是顾客用不同手机号给Phone1、Phone2、Phone3拨打电话的情况,但是机灵的你,想变个花样来看看,比如下面这样的。

UnpivotUnpivot

大家想想看如何实现呢?想下,2分钟后再看哟

先创建数据

 CREATE TABLE dbo.CustomerPhones
(
 CustomerID INT PRIMARY KEY, -- FK
 Phone1 VARCHAR(32),
 Phone2 VARCHAR(32),
 Phone3 VARCHAR(32)
);
INSERT dbo.CustomerPhones
 (CustomerID, Phone1, Phone2, Phone3)
VALUES
 (1,'705-491-1111', '705-491-1110', NULL),
 (2,'613-492-2222', NULL, NULL),
 (3,'416-493-3333', '416-493-3330', '416-493-3339');

 select * from dbo.CustomerPhones

查看数据如下:

DataDataUpivot 实现行转列

 select * from dbo.CustomerPhones -----数据源
 unpivot 
( 
  Phone FOR Phones IN (Phone1, Phone2, Phone3)
   ##Phone1、Phone2、Phone3这些列的结果转为行上的结果,成为一列,
  ##并且有了新的列名为Phone
) up

结果如下:

ResultResult

参考文献:

1.Use SQL Server's UNPIVOT operator to help normalize output

2.SQL之行转列Pivot用法

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。

您可能感兴趣的文章:
  • Pandas透视表(pivot_table)详解
  • pandas pivot_table() 按日期分多列数据的方法
  • C#实现Excel动态生成PivotTable
  • 行转列之SQL SERVER PIVOT与用法详解
  • SQL基础教程之行转列Pivot函数
  • Pandas 重塑(stack)和轴向旋转(pivot)的实现
  • Python Pivot table透视表使用方法解析

标签:那曲 景德镇 柳州 淮安 威海 泸州 荆门 江苏

巨人网络通讯声明:本文标题《SQL知识点之列转行Unpivot函数》,本文关键词  SQL,知识点,之列,转行,Unpivot,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《SQL知识点之列转行Unpivot函数》相关的同类信息!
  • 本页收集关于SQL知识点之列转行Unpivot函数的相关信息资讯供网民参考!
  • 推荐文章