要在函數中應用SQL數組,可以使用以下步驟:
CREATE FUNCTION myFunction(arr INT[]) RETURNS INT[] AS $$
unnest
函數將數組展開為多行數據,例如:SELECT unnest(arr)
例如,下面是一個簡單的示例函數,接收一個整數數組,返回數組中大于10的元素組成的新數組:
CREATE FUNCTION filterArray(arr INT[]) RETURNS INT[] AS $$
DECLARE
filteredArr INT[];
BEGIN
SELECT array_agg(x) INTO filteredArr
FROM unnest(arr) x
WHERE x > 10;
RETURN filteredArr;
END;
$$ LANGUAGE plpgsql;
SELECT filterArray(ARRAY[5, 10, 15, 20]); -- 返回結果為{15,20}