次のような古典的な方法で構築された自己参照階層テーブルがあるとします。
CREATE TABLE test
(name text,id serial primary key,parent_id integer
references test);
insert into test (name,id,parent_id) values
('root1',1,NULL),('root2',2,NULL),('root1sub1',3,1),('root1sub2',4,1),('root
2sub1',5,2),('root2sub2',6,2);
testdb=# select * from test;
name | id | parent_id
-----------+----+-----------
root1 | 1 |
root2 | 2 |
root1sub1 | 3 | 1
root1sub2 | 4 | 1
root2sub1 | 5 | 2
root2sub2 | 6 | 2
私が今必要としているのは、テスト レコードの ID を取得し、添付されたすべてのレコード (指定されたレコードを含む) を複製する関数 (できればプレーン SQL) です。もちろん、複製されたレコードには新しい ID が必要です。望ましい結果は、たとえば次のようになります。
Select * from cloningfunction(2);
name | id | parent_id
-----------+----+-----------
root2 | 7 |
root2sub1 | 8 | 7
root2sub2 | 9 | 7
ポインタはありますか?PostgreSQL 8.3 を使用しています。