PostgreSQL
 sql >> база данни >  >> RDS >> PostgreSQL

Функция за проследяване на зависимости

Следваща стъпка... (продължение на предишния ми отговор).

функция save_views(текст на име на обект) съхранява изгледи в зависимост от име на обект (изглед или таблица) в таблица saved_views .

функция restore_views() възстановява изгледи от таблица saved_views .

create or replace function save_views_oid(objectid oid)
returns void language plpgsql as $$
declare
    r record;
begin
    for r in
        select distinct c.oid, c.relname, n.nspname
        from pg_depend d
        join pg_rewrite w on w.oid = d.objid
        join pg_class c on c.oid = w.ev_class
        join pg_namespace n on n.oid = c.relnamespace
        where d.refclassid = 'pg_class'::regclass 
        and d.classid = 'pg_rewrite'::regclass
        and d.refobjid = objectid
        and c.oid <> objectid
    loop
        insert into saved_views values (
            'CREATE VIEW ' || r.nspname || '.' || r.relname ||
            ' AS ' || pg_get_viewdef(r.oid, 'f'));
        perform save_views_oid(r.oid);
    end loop;
end; $$;

create or replace function save_views(objectname text)
returns void language plpgsql as $$
begin
    create table if not exists saved_views(viewbody text);
    truncate saved_views;
    perform save_views_oid(objectname::regclass);
end; $$;

create or replace function restore_views()
returns void language plpgsql as $$
declare
    viewtext text;
begin
    for viewtext in
        select viewbody from saved_views
    loop
        execute viewtext;
    end loop;
    drop table saved_views;
end; $$;

Тест:

select save_views('my_view'); -- may be save_views('my_schema.my_view');
select * from saved_views;

Използвайте:

select save_views('my_view'); 
drop view my_view cascade;
create view my_view as ...
select restore_views();


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Намерете идентификатор на родител, когато всички деца споделят една и съща стойност

  2. С sqlalchemy как динамично да се свързвате към машината на базата данни на база заявка

  3. PGSQL не е зареден в PHP 5.3 Windows под IIS

  4. PostgreSQL:от OID до Bytea

  5. Как да инсталирате PgBackRest