Redshift drop有依赖关系的表

简介: 今天开发需要删除AWS Redshift的一个归档表,但是直接drop发生了如下报错,发现有其他对象依赖这个表,导致无法直接删除,但是报错没有直接显示是什么对象依赖它,可能是有视图,外键等约束analyticsprod=# DROP TABLE IF EXISTS facts.

今天开发需要删除AWS Redshift的一个归档表,但是直接drop发生了如下报错,发现有其他对象依赖这个表,导致无法直接删除,但是报错没有直接显示是什么对象依赖它,可能是有视图,外键等约束

analyticsprod=# DROP TABLE IF EXISTS facts.auto_events_bk_20170223;

ERROR:  cannot drop table auto_events_bk_20170223 because other objects depend on it

HINT:  Use DROP ... CASCADE to drop the dependent objects too.


通过\d+ auto_events_bk_20170223 查看表结构,发现并没有其他表的外键约束,所以排除;

然后通过\dv+命令在schema:facts下查看视图,但是发现没有任何view存在,但是view可能存在其他schema或db,

那么问题来了,如何在整个数据库中找到与这个表有依赖的的view?


这里AWS Redshift已经给我们提供了一个好的方法,参考链接:https://docs.aws.amazon.com/redshift/latest/dg/r_DROP_TABLE.html


创建一个视图find_depend:

create view find_depend as
select distinct c_p.oid as tbloid,
n_p.nspname as schemaname, c_p.relname as name,
n_c.nspname as refbyschemaname, c_c.relname as refbyname,
c_c.oid as viewoid
from pg_catalog.pg_class c_p
join pg_catalog.pg_depend d_p
on c_p.relfilenode = d_p.refobjid
join pg_catalog.pg_depend d_c
on d_p.objid = d_c.objid
join pg_catalog.pg_class c_c
on d_c.refobjid = c_c.relfilenode
left outer join pg_namespace n_p
on c_p.relnamespace = n_p.oid
left outer join pg_namespace n_c
on c_c.relnamespace = n_c.oid
where d_c.deptype = 'i'::"char"
and c_c.relkind = 'v'::"char";



查询视图找到与表auto_events_bk_20170223相关的view:


analyticsprod=# select * from facts.find_depend where schemaname='facts' and name not in ('find_depend') order by name;
 tbloid | schemaname |          name           | refbyschemaname |  refbyname  | viewoid
--------+------------+-------------------------+-----------------+-------------+---------
 879566 | facts      | auto_events_bk_20170223 | public          | map_routes2 |  965969
 879566 | facts      | auto_events_bk_20170223 | public          | map_routes  |  966155
 879566 | facts      | auto_events_bk_20170223 | public          | map_edges   | 1019697
(3 rows)

analyticsprod=# set search_path to public;

analyticsprod=# \dv
               List of relations
 schema |         name          | type | owner
--------+-----------------------+------+-------
 public | map_edges             | view | fengw
 public | map_edges_group       | view | fengw
 public | map_route_edges_group | view | fengw
 public | map_routes            | view | fengw
 public | map_routes2           | view | fengw
 public | map_routes_group      | view | fengw
(6 rows)




最后如果判断这些相关的view没有用的话,可以通过命令drop table auto_events_bk_20170223 cascade删除表,包括视图一同删除。


目录
相关文章
|
4月前
|
SQL
在云数据仓库ADB中,可以使用UPDATE语句进行单表更新和多表关联更新。
在云数据仓库ADB中,可以使用UPDATE语句进行单表更新和多表关联更新。
80 2
|
7天前
|
关系型数据库 PostgreSQL
postgresql将没有关联关系的两张表合并成一张
【5月更文挑战第4天】postgresql将没有关联关系的两张表合并成一张
18 5
|
4月前
|
SQL
在云数据仓库ADB中,可以使用UPDATE语句进行单表更新和多表关联更新
【1月更文挑战第11天】【1月更文挑战第54篇】在云数据仓库ADB中,可以使用UPDATE语句进行单表更新和多表关联更新
43 1
|
10月前
|
关系型数据库
GreenPlum和openGauss进行简单聚合时对扫描列的区别
GreenPlum和openGauss进行简单聚合时对扫描列的区别
88 0
|
SQL 数据库 数据库管理
Sqlite升级时向已有表中增加字段
Sqlite数据库升级时,我们经常会遇到给已有表中增加字段的操作。一般来说,**给已有表中增加字段**是数据库操作中的基操,没必要再专门写篇blog记录的,但是sqlite对SQL语句支持的不够彻底,比方说这次我们用到的"ALTER TABLE"命令。
|
SQL 物联网 Shell
SQLite 虚拟表和触发器操作联结表 | 学习笔记
快速学习 SQLite 虚拟表和触发器操作联结表
314 0
|
SQL 数据库 数据库管理
数据库和数据表 建立索引的原则
索引查询是数据库中重要的记录查询方法,要不要进入索引以及在那些字段上建立索引都要和实际数据库系统的查询要求结合来考虑,下面给出实际中的一些通用的原则:
|
SQL 数据库
使用 DDL 语句分别创建仓库表、供应商表、产品表和入库表,并对其进行操作
使用 DDL 语句分别创建仓库表、供应商表、产品表和入库表,并对其进行操作
159 0
|
SQL 存储 大数据
Apache Hive--DDL--创建表--分桶表总结&分桶表好处| 学习笔记
快速学习 Apache Hive--DDL--创建表--分桶表总结&分桶表好处
133 0
Apache Hive--DDL--创建表--分桶表总结&分桶表好处| 学习笔记
|
Web App开发 存储 关系型数据库
InnoDB 层系统字典表 | 全方位认识 information_schema
在《Server 层混杂信息字典表 | 全方位认识 information_schema》中,我们详细介绍了information_schema下的状态变量、系统变量、进程状态、字符集和校对规则等字典表,本期我们将为大家带来系列第五篇《InnoDB 层系统字典表 | 全方位认识 information_schema》,下面请跟随我们一起开始information_schema 系统库的系统学习之旅吧。
3116 0