sql >> Databáze >  >> RDS >> PostgreSQL

Najděte závislé objekty pro tabulku nebo pohled

Navrhované řešení pro mě nefungovalo s postgresql 9.1.4

toto fungovalo:

SELECT dependent_ns.nspname as dependent_schema
, dependent_view.relname as dependent_view 
, source_ns.nspname as source_schema
, source_table.relname as source_table
, pg_attribute.attname as column_name
FROM pg_depend 
JOIN pg_rewrite ON pg_depend.objid = pg_rewrite.oid 
JOIN pg_class as dependent_view ON pg_rewrite.ev_class = dependent_view.oid 
JOIN pg_class as source_table ON pg_depend.refobjid = source_table.oid 
JOIN pg_attribute ON pg_depend.refobjid = pg_attribute.attrelid 
    AND pg_depend.refobjsubid = pg_attribute.attnum 
JOIN pg_namespace dependent_ns ON dependent_ns.oid = dependent_view.relnamespace
JOIN pg_namespace source_ns ON source_ns.oid = source_table.relnamespace
WHERE 
source_ns.nspname = 'my_schema'
AND source_table.relname = 'my_table'
AND pg_attribute.attnum > 0 
AND pg_attribute.attname = 'my_column'
ORDER BY 1,2;


  1. Nelze načíst ID posledního vloženého řádku v režimu spánku pomocí Oracle

  2. #1071 - Zadaný klíč byl příliš dlouhý; maximální délka klíče je 1000 bajtů

  3. MySQL – řádky do sloupců

  4. chyba syntaxe s aktualizačním dotazem při spojení s nějakou tabulkou