2000-06-19 22:02:16 +08:00
|
|
|
|
|
|
|
findoidjoins
|
|
|
|
|
2002-04-25 10:56:56 +08:00
|
|
|
This program scans a database, and prints oid fields (also regproc, regclass
|
|
|
|
and regtype fields) and the tables they join to. CAUTION: it is ver-r-r-y
|
|
|
|
slow on a large database, or even a not-so-large one. We don't really
|
|
|
|
recommend running it on anything but an empty database, such as template1.
|
2000-06-19 22:02:16 +08:00
|
|
|
|
|
|
|
Uses pgeasy library.
|
|
|
|
|
|
|
|
Run on an empty database, it returns the system join relationships (shown
|
2001-08-11 02:57:42 +08:00
|
|
|
below for 7.2). Note that unexpected matches may indicate bogus entries
|
2000-06-19 22:02:16 +08:00
|
|
|
in system tables --- don't accept a peculiar match without question.
|
|
|
|
In particular, a field shown as joining to more than one target table is
|
2001-08-11 02:57:42 +08:00
|
|
|
probably messed up. In 7.2, the *only* field that should join to more
|
2000-06-19 22:02:16 +08:00
|
|
|
than one target is pg_description.objoid. (Running make_oidjoins_check
|
|
|
|
is an easy way to spot fields joining to more than one table, BTW.)
|
|
|
|
|
|
|
|
The shell script make_oidjoins_check converts findoidjoins' output
|
|
|
|
into an SQL script that checks for dangling links (entries in an
|
|
|
|
OID or REGPROC column that don't match any row in the expected table).
|
|
|
|
Note that fields joining to more than one table are NOT processed.
|
|
|
|
|
|
|
|
The result of make_oidjoins_check should be installed as the "oidjoins"
|
|
|
|
regression test. The oidjoins test should be updated after any
|
|
|
|
revision in the patterns of cross-links between system tables.
|
|
|
|
(Ideally we'd just regenerate the script as part of the regression
|
|
|
|
tests themselves, but that seems too slow...)
|
|
|
|
|
2001-08-11 02:57:42 +08:00
|
|
|
NOTE: in 7.2, make_oidjoins_check produces one bogus join check, for
|
|
|
|
pg_class.relfilenode => pg_class.oid. This is an artifact and should not
|
2001-02-10 11:57:42 +08:00
|
|
|
be added to the oidjoins regress test.
|
|
|
|
|
2000-06-19 22:02:16 +08:00
|
|
|
---------------------------------------------------------------------------
|
|
|
|
|
2001-02-10 11:57:42 +08:00
|
|
|
Join pg_aggregate.aggtransfn => pg_proc.oid
|
2000-06-19 22:02:16 +08:00
|
|
|
Join pg_aggregate.aggfinalfn => pg_proc.oid
|
|
|
|
Join pg_aggregate.aggbasetype => pg_type.oid
|
2001-02-10 11:57:42 +08:00
|
|
|
Join pg_aggregate.aggtranstype => pg_type.oid
|
2000-06-19 22:02:16 +08:00
|
|
|
Join pg_aggregate.aggfinaltype => pg_type.oid
|
|
|
|
Join pg_am.amgettuple => pg_proc.oid
|
|
|
|
Join pg_am.aminsert => pg_proc.oid
|
|
|
|
Join pg_am.ambeginscan => pg_proc.oid
|
|
|
|
Join pg_am.amrescan => pg_proc.oid
|
|
|
|
Join pg_am.amendscan => pg_proc.oid
|
|
|
|
Join pg_am.ammarkpos => pg_proc.oid
|
|
|
|
Join pg_am.amrestrpos => pg_proc.oid
|
|
|
|
Join pg_am.ambuild => pg_proc.oid
|
2001-08-11 02:57:42 +08:00
|
|
|
Join pg_am.ambulkdelete => pg_proc.oid
|
2000-06-19 22:02:16 +08:00
|
|
|
Join pg_am.amcostestimate => pg_proc.oid
|
|
|
|
Join pg_amop.amopclaid => pg_opclass.oid
|
|
|
|
Join pg_amop.amopopr => pg_operator.oid
|
|
|
|
Join pg_amproc.amopclaid => pg_opclass.oid
|
|
|
|
Join pg_amproc.amproc => pg_proc.oid
|
|
|
|
Join pg_attribute.attrelid => pg_class.oid
|
|
|
|
Join pg_attribute.atttypid => pg_type.oid
|
|
|
|
Join pg_class.reltype => pg_type.oid
|
|
|
|
Join pg_class.relam => pg_am.oid
|
2001-02-10 11:57:42 +08:00
|
|
|
Join pg_class.reltoastrelid => pg_class.oid
|
|
|
|
Join pg_class.reltoastidxid => pg_class.oid
|
2001-08-11 02:57:42 +08:00
|
|
|
Join pg_description.classoid => pg_class.oid
|
2000-06-19 22:02:16 +08:00
|
|
|
Join pg_index.indexrelid => pg_class.oid
|
|
|
|
Join pg_index.indrelid => pg_class.oid
|
2001-08-22 00:36:06 +08:00
|
|
|
Join pg_opclass.opcamid => pg_am.oid
|
|
|
|
Join pg_opclass.opcintype => pg_type.oid
|
2000-06-19 22:02:16 +08:00
|
|
|
Join pg_operator.oprleft => pg_type.oid
|
|
|
|
Join pg_operator.oprright => pg_type.oid
|
|
|
|
Join pg_operator.oprresult => pg_type.oid
|
|
|
|
Join pg_operator.oprcom => pg_operator.oid
|
|
|
|
Join pg_operator.oprnegate => pg_operator.oid
|
|
|
|
Join pg_operator.oprlsortop => pg_operator.oid
|
|
|
|
Join pg_operator.oprrsortop => pg_operator.oid
|
|
|
|
Join pg_operator.oprcode => pg_proc.oid
|
|
|
|
Join pg_operator.oprrest => pg_proc.oid
|
|
|
|
Join pg_operator.oprjoin => pg_proc.oid
|
|
|
|
Join pg_proc.prolang => pg_language.oid
|
|
|
|
Join pg_proc.prorettype => pg_type.oid
|
|
|
|
Join pg_rewrite.ev_class => pg_class.oid
|
|
|
|
Join pg_statistic.starelid => pg_class.oid
|
2001-08-11 02:57:42 +08:00
|
|
|
Join pg_statistic.staop1 => pg_operator.oid
|
|
|
|
Join pg_statistic.staop2 => pg_operator.oid
|
|
|
|
Join pg_statistic.staop3 => pg_operator.oid
|
2000-06-19 22:02:16 +08:00
|
|
|
Join pg_trigger.tgrelid => pg_class.oid
|
|
|
|
Join pg_trigger.tgfoid => pg_proc.oid
|
|
|
|
Join pg_type.typrelid => pg_class.oid
|
|
|
|
Join pg_type.typelem => pg_type.oid
|
|
|
|
Join pg_type.typinput => pg_proc.oid
|
|
|
|
Join pg_type.typoutput => pg_proc.oid
|
|
|
|
Join pg_type.typreceive => pg_proc.oid
|
|
|
|
Join pg_type.typsend => pg_proc.oid
|
|
|
|
|
|
|
|
---------------------------------------------------------------------------
|
|
|
|
|
|
|
|
Bruce Momjian (root@candle.pha.pa.us)
|