在 Oracle 中,CONNECT BY 是一種用于處理層次化數據結構(例如樹形結構)的查詢語句。通過 CONNECT BY,我們可以在查詢結果中顯示每個節點及其父節點和子節點之間的關系。
下面是一個示例,假設我們有一個包含員工信息的表 Employee,其中包含員工的 ID、姓名和上級員工的 ID。我們可以使用 CONNECT BY 查詢語句來顯示員工的層次結構。
首先,創建 Employee 表并插入一些示例數據:
CREATE TABLE Employee (
employee_id NUMBER,
employee_name VARCHAR2(50),
manager_id NUMBER
);
INSERT INTO Employee VALUES (1, 'Alice', NULL);
INSERT INTO Employee VALUES (2, 'Bob', 1);
INSERT INTO Employee VALUES (3, 'Charlie', 1);
INSERT INTO Employee VALUES (4, 'David', 2);
然后,使用 CONNECT BY 查詢語句來顯示員工的層次結構:
SELECT LPAD(' ', 2*(LEVEL-1)) || employee_name AS employee_hierarchy
FROM Employee
START WITH manager_id IS NULL
CONNECT BY PRIOR employee_id = manager_id;
在上面的查詢中,LEVEL 是 Oracle 中的偽列,它表示當前行在結果集中的層次。CONNECT BY PRIOR 子句用于指定父節點與子節點之間的關系。通過使用 LPAD 函數來縮進每個節點,我們可以更清晰地顯示層次結構。
執行以上查詢語句,將得到如下輸出:
Alice
Bob
David
Charlie
這顯示了員工 Alice 作為頂級節點,Bob 和 Charlie 是其下級員工,而 David 是 Bob 的下級員工。這就是 CONNECT BY 在樹形結構中的應用。