博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
postgresql/greenplum查询依赖于表上的视图
阅读量:4031 次
发布时间:2019-05-24

本文共 1005 字,大约阅读时间需要 3 分钟。

       在postgresql、greenplum中,我们经常需要重建某张表,为了方便回滚,我们一般将原表rename掉,然后重建原表。

       这样子,就会有一个问题:依赖于原表的视图还是依赖于rename的表,没有依赖于新表。这是因为视图定义的时候是根据表的oid来定义了,原表rename后,oid没有变,这样子就导致了视图依赖错误的表。

       查询依赖于某一个表的视图比较麻烦,要通过pg_depend这个数据字典来查询,但是用起来很不方便。

       下面提供一个视图,方便查询依赖于表上的视图。

1.首先定义一个函数,将oid快速转换成schemaname.tablename.

CREATE or replace FUNCTION public.tabname_oid(a oid)  RETURNS textAS $$  return plpy.execute("select b.nspname||'.'||a.relname as tabname from pg_class a,pg_namespace b wherea.relnamespace=b.oid and a.oid=%s"%(a))[0]['tabname'];$$ LANGUAGE plpythonu;
2.建立查询视图

create view public.views_on_tables as    select tabname_oid(c.ev_class) viewname,tabname_oid(pc.oid) tablename     from pg_depend a,pg_depend b,pg_class pc,pg_rewrite c    where a.refclassid=1259            and b.deptype='i'      and a.classid=2618      and a.objid=b.objid      and a.classid=b.classid      and a.refclassid=b.refclassid      and a.refobjid<>b.refobjid      and pc.oid=a.refobjid           and c.oid=b.objid      group by c.ev_class,pc.oid;
3.效果如下:

  

转载地址:http://leebi.baihongyu.com/

你可能感兴趣的文章
WPF中PATH使用AI导出SVG的方法
查看>>
WPF UI&控件免费开源库
查看>>
QT打开项目提示no valid settings file could be found
查看>>
Win10+VS+ESP32环境搭建
查看>>
Ubuntu+win10远程桌面
查看>>
flutter-实现圆角带边框的view(android无效)
查看>>
flutter-实现一个下拉刷新上拉加载的列表
查看>>
android 代码实现圆角
查看>>
flutter-解析json
查看>>
android中shader的使用
查看>>
java LinkedList与ArrayList迭代器遍历和for遍历对比
查看>>
Android DataBinding使用2-Recycleview
查看>>
drat中构造方法
查看>>
JavaScript的一些基础-数据类型
查看>>
JavaScript基础知识(2)
查看>>
转载一个webview开车指南以及实际项目中的使用
查看>>
android中对于非属性动画的整理
查看>>
一个简单的TabLayout的使用
查看>>
关于let{a}=B出现的解构赋值
查看>>
ReactNative使用Redux例子
查看>>