Działałoby to tak:
CREATE OR REPLACE FUNCTION name_function(param_1 varchar
, OUT param_2 bigint)
LANGUAGE plpgsql AS
$func$
BEGIN
INSERT INTO table (collumn_seq, param_1) -- "param_1" also the column name?
VALUES (DEFAULT, param_1)
RETURNING collumn_seq
INTO param2;
END
$func$;
Normalnie dodałbyś RETURN
oświadczenie, ale z OUT
parametrów, jest to opcjonalne.
Więcej informacji można znaleźć w instrukcji:
- Powrót z funkcji
- Wykonywanie zapytania z wynikiem jednowierszowym
Prosty przypadek można opisać zwykłą funkcją SQL.
Możesz też pominąć kolumnę docelową, która otrzyma swoją DEFAULT
wartość.
I możesz równie dobrze użyć RETURNS
klauzula w tym przypadku:
CREATE OR REPLACE FUNCTION name_function(param_1 varchar)
RETURNS bigint
LANGUAGE sql AS
$func$
INSERT INTO table (param_1) -- "param_1" also the column name?
VALUES (param_1)
RETURNING collumn_seq;
$func$;