Memisahkan Rentetan Diberi
Untuk memisahkan tarikh (p_dates) dan set (p_sets) yang diberikan, kita boleh menggunakan fungsi string_split() bagi Postgres. string_split() mengambil dua argumen: rentetan input untuk dipecah dan pembatas.
SELECT string_split(p_dates, ','); SELECT string_split(p_sets, ',');
Ini akan mengembalikan dua tatasusunan yang mengandungi tarikh dan set pecahan.
Menyediakan Kes Dinamik Pernyataan
Untuk menyediakan pernyataan kes dinamik, kita boleh menggelung melalui tatasusunan berpecah dan membina pernyataan menggunakan ungkapan CASE.
DECLARE p_dates TEXT := '2001-01-01to2001-01-05,2001-01-10to2001-01-15'; p_sets TEXT := 's1,s2'; CASE_STATEMENT TEXT := 'CASE '; BEGIN FOR p_date IN SELECT * FROM string_split(p_dates, ',') LOOP CASE_STATEMENT := CASE_STATEMENT || 'WHEN given_dates BETWEEN ' || quote_literal(p_date) || ' ' || ... END LOOP; FOR p_set IN SELECT * FROM string_split(p_sets, ',') LOOP CASE_STATEMENT := CASE_STATEMENT || 'THEN ' || quote_literal(p_set) || ' ' END LOOP; -- Complete Case Statement with ELSE clause to assign NULL if no match CASE_STATEMENT := CASE_STATEMENT || 'ELSE NULL' || ' END'; END; SELECT CASE_STATEMENT;
CASE_STATEMENT yang terhasil akan menjadi ungkapan kes dinamik yang memberikan nama set yang sesuai berdasarkan julat tarikh yang diberikan.
CASE WHEN given_dates BETWEEN '2001-01-01' AND '2001-01-05' THEN 's1' WHEN given_dates BETWEEN '2001-01-10' AND '2001-01-15' THEN 's2' ELSE NULL END
Anda boleh menggunakan CASE_STATEMENT dinamik ini dalam pertanyaan kemas kini anda untuk menetapkan nama yang ditetapkan mengikut julat tarikh yang diberikan dan nama yang ditetapkan.
Atas ialah kandungan terperinci Bagaimana untuk Menjana Penyata KES secara Dinamik dalam Postgres untuk Tugasan Set Berdasarkan Tarikh?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!