Jeg tilføjer her den komplette løsning til at oprette typer i et simpelt script, uden at det er nødvendigt at oprette en funktion kun til dette formål.
--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$$;