首页主机资讯oracle怎么实现行转列

oracle怎么实现行转列

时间2023-12-09 07:35:03发布访客分类主机资讯浏览562
导读:在Oracle中,可以使用PIVOT关键字将行转列。PIVOT将一列的值转换为多个列,并将行数据重新组织为新的列。 以下是一个示例: 假设有一个名为employee的表,包含如下数据: employee_id department_i...

在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函数作为聚合函数,将每个部门的职位值填充到对应的新列中。

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!


若转载请注明出处: oracle怎么实现行转列
本文地址: https://pptw.com/jishu/574398.html
python中randint的用法是什么 linux中怎么查看对外端口

游客 回复需填写必要信息