OK, tôi đã tìm ra giải pháp:
CREATE OR REPLACE FUNCTION getProductById(cid int) RETURNS RECORD AS $$
DECLARE
result RECORD;
BEGIN
EXECUTE 'SELECT * FROM ' || (SELECT ('products.' || (select category_name from category where category_id = cid) || '_view')::regclass) INTO result;
RETURN result;
END;
$$ LANGUAGE plpgsql;
và để chọn:
SELECT * FROM getProductById(7) AS b (category_id int, ... );
hoạt động cho PostgreSQL 9.x