阅读量:1
在Oracle中,可以使用PIVOT关键字将行转列。PIVOT将一列的值转换为多个列,并将行数据重新组织为新的列。
以下是一个示例:
假设有一个名为employee的表,包含如下数据:
| employee_id | department_id | job_title |
|---|---|---|
| 1 | 101 | Manager |
| 2 | 101 | Assistant |
| 3 | 102 | Clerk |
| 4 | 102 | Analyst |
| 5 | 103 | Technician |
现在我们想要将每个部门的员工职位转换为列,可以使用PIVOT关键字进行操作:
SELECT *
FROM
(
SELECT employee_id, department_id, job_title
FROM employee
)
PIVOT
(
MAX(job_title)
FOR department_id IN (101, 102, 103)
);
执行以上查询语句,将会得到以下结果:
| employee_id | 101_Manager | 101_Assistant | 102_Clerk | 102_Analyst | 103_Technician |
|---|---|---|---|---|---|
| 1 | Manager | ||||
| 2 | Assistant | ||||
| 3 | Clerk | ||||
| 4 | Analyst | ||||
| 5 | Technician |
在PIVOT子句中,我们指定了用于新列的部门ID值(101, 102, 103)。并且我们使用MAX函数作为聚合函数,将每个部门的职位值填充到对应的新列中。
以上就是关于“oracle怎么实现行转列”的相关介绍,筋斗云是国内较早的云主机应用的服务商,拥有10余年行业经验,提供丰富的云服务器、租用服务器等相关产品服务。云服务器资源弹性伸缩,主机vCPU、内存性能强悍、超高I/O速度、故障秒级恢复;电子化备案,提交快速,专业团队7×24小时服务支持!
简单好用、高性价比云服务器租用链接:https://www.jindouyun.cn/product/cvm