Ik voeg hier de complete oplossing toe voor het maken van typen in een eenvoudig script, zonder dat er speciaal voor dit doel een functie hoeft te worden gemaakt.
--create types
DO $$
BEGIN
IF NOT EXISTS (SELECT 1 FROM pg_type WHERE typname = 'my_type') THEN
CREATE TYPE my_type AS
(
--my fields here...
);
END IF;
--more types here...
END$$;