私のデータベースに対して次のスキームを実行します。
create sequence data_sequence;
create table data_table
{
id integer primary key;
field varchar(100);
};
create view data_view as
select id, field from data_table;
create function data_insert(_new data_view) returns data_view as
$$declare
_id integer;
_result data_view%rowtype;
begin
_id := nextval('data_sequence');
insert into data_table(id, field) values(_id, _new.field);
select * into _result from data_view where id = _id;
return _result;
end;
$$
language plpgsql;
create rule insert as on insert to data_view do instead
select data_insert(new);
次に、psqlと入力します。
insert into data_view(field) values('abc');
次のようなものを見たい:
id | field
----+---------
1 | abc
代わりに、以下を参照してください。
data_insert
-------------
(1, "abc")
どういうわけかこれを修正することは可能ですか?
アイデアをありがとう。
最終的には、これを他の関数で使用して、挿入したばかりのレコードのIDを最初から選択せずに取得できるようにすることです。何かのようなもの:
insert into data_view(field) values('abc') returning id into my_variable
いいのですが、エラーでは機能しません:
ERROR: cannot perform INSERT RETURNING on relation "data_view"
HINT: You need an unconditional ON INSERT DO INSTEAD rule with a RETURNING clause.
私はそのヒントを本当に理解していません。私はPostgreSQL8.4を使用しています。