在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函數作為聚合函數,將每個部門的職位值填充到對應的新列中。