たとえば、次のように作成された 2 つのスキーマと 4 つのテーブルがあるとします。
create table a.foo(
id integer primary key,
val integer);
create table b.main(
id serial primary key,
val integer references a.foo(id));
create table b.foo(
k integer primary key references b.main(id),
v timestamp with time zone);
create table b.bar(
k integer primary key references b.main(id),
v timestamp with time zone);
私が探しているものの疑似コード: b.main.id が参照されているすべてのテーブルを選択します。
結果は次のようになります。
b.main.id | b.main.val | b.foo.k | b.foo.v | b.bar.k | b.bar.v
1 1 1 TimeStamp 1 TimeStamp
2 1 2 .... 2 ....
現在、このクエリを次のように実装しています。
select * from b.main,
(select *
from b.foo,
(select * from b.bar where b.bar.v > somedate) as morebar
where b.bar.k = b.foo.k) as morefoo
where b.main.id = b.foo.k;
質問に戻ります。主キーを参照するすべてのテーブルで選択を実行できる Postgres の機能はありますか? 私の場合、b.main.id を参照するすべてのテーブル。
Postgresql のドキュメントを検索しましたが、探しているものが見つかりません。提案?