私は次で終わる関数を持っています:
INSERT INTO configuration_dates (
cols...
) VALUES (
values...
) RETURNING id INTO ret_id;
RETURN ret_id;
そして、INTO ret_id
の部分を削除して、代わりに次のようにします。
RETURN (INSERT INTO configuration_dates (
weekly_date_configuration_id,
"from",
"to",
price,
activity_configuration_id
) VALUES (
wdc_id,
from_ts,
from_ts + wdc.duration,
wdc.price,
wdc.activity_configuration_id
) RETURNING id);
しかし、私はこれを達成する方法を見つけていません。
編集:関数全体を追加
CREATE FUNCTION make_date_from_configuration(wdc_id UUID, from_date DATE)
RETURNS INTEGER AS $$
DECLARE
from_dow INT := EXTRACT(isodow FROM from_date); -- day of the week (1 - 7)
wdc weekly_date_configurations;
from_ts TIMESTAMP;
ret_id INTEGER;
BEGIN
SELECT * INTO wdc
FROM weekly_date_configurations wdc
WHERE id = wdc_id;
IF FOUND
AND wdc.valid_through @> from_date -- starts in the date range
AND get_bit(wdc.weekdays, from_dow - 1) = 1 -- valid day of the week
THEN
from_ts := from_date || ' ' || wdc.start_time;
INSERT INTO configuration_dates (
weekly_date_configuration_id,
"from",
"to",
price,
activity_configuration_id
) VALUES (
wdc_id,
from_ts,
from_ts + wdc.duration,
wdc.price,
wdc.activity_configuration_id
) RETURNING id INTO ret_id;
RETURN ret_id;
ELSE
RETURN NULL;
END IF;
END;
$$ LANGUAGE plpgsql;
関数全体を簡略化してOUT
パラメータを使用すると、値が関数の最後に自動的に返されます。
CREATE OR REPLACE FUNCTION make_date_from_configuration(
wdc_id uuid
, from_date date
, OUT ret_id int) AS
$func$
BEGIN
INSERT INTO configuration_dates (
weekly_date_configuration_id, "from", "to", price, activity_configuration_id)
SELECT wdc_id
, (from_date || ' ' || wdc.start_time)::timestamptz
, (from_date || ' ' || wdc.start_time)::timestamptz + wdc.duration
, wdc.price, wdc.activity_configuration_id
FROM weekly_date_configurations wdc
WHERE wdc.id = wdc_id
AND wdc.valid_through @> from_date -- starts in the date range
AND get_bit(wdc.weekdays
, EXTRACT(isodow FROM from_date)::int - 1) = 1 -- valid day of the week
RETURNING id
INTO ret_id; -- returned at the end automatically
END
$func$ LANGUAGE plpgsql;
すべての変数、割り当て、条件式は、不要なノイズです。単一のSQLコマンドにすることができます:短くて高速です。
ただし、INTO
句は必要です。 (そして、あなたがそれを避けようとする理由がわかりません。)
Or代わりにプレーンSQL関数を使用して、値を直接返すことができます。
CREATE OR REPLACE FUNCTION make_date_from_configuration(wdc_id uuid, from_date date)
RETURNS int AS
$func$
INSERT INTO configuration_dates (
weekly_date_configuration_id, "from", "to", price, activity_configuration_id )
SELECT wdc_id
, (from_date || ' ' || wdc.start_time)::timestamptz
, (from_date || ' ' || wdc.start_time)::timestamptz + wdc.duration
, wdc.price, wdc.activity_configuration_id
FROM weekly_date_configurations wdc
WHERE wdc.id = wdc_id
AND wdc.valid_through @> from_date -- starts in the date range
AND get_bit(wdc.weekdays
, EXTRACT(isodow FROM from_date)::int- 1) = 1 -- valid day of the week
RETURNING id -- return directly
$func$ LANGUAGE sql;
RETURN QUERY
を使用します
RETURN QUERY ...
または、RETURNS TABLE
関数やRETURNS SETOF ...
関数ではなく単一の行を返す場合は、結果をレコード値変数に格納して返すことができると思います。未テスト:
DECLARE
my_result record;
BEGIN
INSERT INTO ...
RETURNING ...
INTO my_result;
RETURN my_result;
END;