Một hàm được lưu trữ ( hoặc thủ tục ) có thể được tạo để tạo SQL cho Dynamic Pivoting và tập kết quả được tải vào một biến kiểu SYS_REFCURSOR
:
CREATE OR REPLACE FUNCTION Get_Categories_RS RETURN SYS_REFCURSOR IS
v_recordset SYS_REFCURSOR;
v_sql VARCHAR2(32767);
v_cols_1 VARCHAR2(32767);
v_cols_2 VARCHAR2(32767);
BEGIN
SELECT LISTAGG( ''''||"level"||''' AS "'||"level"||'"' , ',' )
WITHIN GROUP ( ORDER BY "level" DESC )
INTO v_cols_1
FROM (
SELECT DISTINCT "level"
FROM temp
);
SELECT LISTAGG( 'MAX(CASE WHEN category = '''||category||''' THEN "'||"level"||'" END) AS "'||"level"||'_'||category||'"' , ',' )
WITHIN GROUP ( ORDER BY category, "level" DESC )
INTO v_cols_2
FROM (
SELECT DISTINCT "level", category
FROM temp
);
v_sql :=
'SELECT "set", '|| v_cols_2 ||'
FROM
(
SELECT *
FROM temp
PIVOT
(
MAX(value) FOR "level" IN ( '|| v_cols_1 ||' )
)
)
GROUP BY "set"
ORDER BY "set"';
OPEN v_recordset FOR v_sql;
RETURN v_recordset;
END;
trong đó tôi đã sử dụng hai mức xoay vòng:mức đầu tiên nằm trong truy vấn bên trong liên quan đến PIVOT
Mệnh đề và mệnh đề thứ hai là trong truy vấn bên ngoài có logic tổng hợp có điều kiện. Lưu ý rằng thứ tự các cấp phải theo thứ tự giảm dần (Z
, Y
, X
) trong kết quả mong đợi vì phù hợp với mô tả.
Và sau đó gọi
VAR rc REFCURSOR
EXEC :rc := Get_Categories_RS;
PRINT rc
từ Dòng lệnh của Nhà phát triển SQL để có được tập hợp kết quả
Btw, tránh sử dụng các từ khóa dành riêng như set
và level
như trong trường hợp của bạn. Tôi cần phải trích dẫn chúng để có thể sử dụng.