Wypróbuj:
CREATE OR REPLACE FUNCTION outer() RETURNS void AS $outer$
DECLARE s text;
BEGIN
CREATE OR REPLACE FUNCTION inner() RETURNS text AS $inner$
BEGIN
RETURN 'inner';
END;
$inner$ language plpgsql;
SELECT inner() INTO s;
RAISE NOTICE '%', s;
DROP FUNCTION inner();
END;
$outer$ language plpgsql;
W postgresie 9.5 SELECT outer();
wyjścia
psql:/vagrant/f.sql:14: NOTICE: inner
EDYCJA:jeśli nie usuniesz funkcji wewnętrznej na końcu funkcji zewnętrznej, pozostanie ona widoczna dla reszty bazy danych.