oracle怎么实现行转列

   2025-02-15 5480
核心提示:在Oracle中,可以使用PIVOT关键字将行转列。PIVOT将一列的值转换为多个列,并将行数据重新组织为新的列。以下是一个示例:假设有

在Oracle中,可以使用PIVOT关键字将行转列。PIVOT将一列的值转换为多个列,并将行数据重新组织为新的列。

以下是一个示例:

假设有一个名为employee的表,包含如下数据:

employee_iddepartment_idjob_title
1101Manager
2101Assistant
3102Clerk
4102Analyst
5103Technician

现在我们想要将每个部门的员工职位转换为列,可以使用PIVOT关键字进行操作:

SELECT *FROM(  SELECT employee_id, department_id, job_title  FROM employee)PIVOT(  MAX(job_title)  FOR department_id IN (101, 102, 103));

执行以上查询语句,将会得到以下结果:

employee_id101_Manager101_Assistant102_Clerk102_Analyst103_Technician
1Manager
2Assistant
3Clerk
4Analyst
5Technician

在PIVOT子句中,我们指定了用于新列的部门ID值(101, 102, 103)。并且我们使用MAX函数作为聚合函数,将每个部门的职位值填充到对应的新列中。

 
 
更多>同类维修知识
推荐图文
推荐维修知识
点击排行
网站首页  |  关于我们  |  联系方式  |  用户协议  |  隐私政策  |  网站留言