Nah, ada yang aneh. Saya melakukannya:
[email protected]@[local] =# create function abuse_resolve(inout __abuse_id bigint,
out __msg text) returns record language plpgsql as
$$ begin __msg = 'ok'; end; $$;
CREATE FUNCTION
[email protected]@[local] =# \df abuse_resolve
List of functions
-[ RECORD 1 ]-------+----------------------------------------
Schema | so9679418
Name | abuse_resolve
Result data type | record
Argument data types | INOUT __abuse_id bigint, OUT __msg text
Type | normal
[email protected]@[local] =# select abuse_resolve('30'::bigint);
-[ RECORD 1 ]-+--------
abuse_resolve | (30,ok)
Apakah Anda memiliki masalah lain dengan database ini? Bisakah Anda menyalinnya dengan dump/restore dan coba ini pada salinan baru? Apakah secara eksplisit mengkualifikasi nama fungsi dengan skema "publik" membantu? Versi PostgreSQL mana yang Anda gunakan?
perbarui:fungsi sql Ini juga berfungsi dengan baik untuk saya menggunakan:
create function abuse_resolve(inout __abuse_id bigint, out __msg text)
language sql as $$ select $1, 'ok'::text $$;