PostgreSQL
 sql >> Teknologi Basis Data >  >> RDS >> PostgreSQL

Fungsi Pelacakan Ketergantungan

Langkah selanjutnya... (lanjutan dari jawaban saya sebelumnya).

fungsi save_views(teks nama objek) menyimpan tampilan tergantung pada nama objek (tampilan atau tabel) dalam tabel saved_views .

fungsi restore_views() memulihkan tampilan dari tabel 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; $$;

Tes:

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

Gunakan:

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. Apakah mungkin menggunakan dua database berbeda untuk aplikasi web offline

  2. Oracle ke PostgreSQL:sintaks gabungan luar ANSI di PostgreSQL

  3. Bagaimana Pi() Bekerja di PostgreSQL

  4. Gabungkan nilai boolean menjadi true jika salah satu kolom sumber benar

  5. ResultSet besar pada kueri postgresql