Redshift drop有依赖关系的表
admin
2023-05-20 22:22:57
0

今天开发需要删除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删除表,包括视图一同删除。


相关内容

热门资讯

缅甸发生5.2级地震,震源深度... 中国地震台网正式测定:05月18日10时05分在缅甸(北纬16.55度,东经96.25度)发生5.2...
大学校门如何正确地开放 武汉大学校门开放后的第一个周末,情况如我的预期。如部分游客存在爬树拍照打卡、在操场直播学生上体育课等...
文科改名潮:加了“智能”二字,... 过去几年里,“文科无用”“文科就业难”的讨论不断发酵。高校文科专业的变动也频繁且剧烈,据教育部数据,...
赛力斯申请多轴机器人运动轨迹校... 国家知识产权局信息显示,重庆赛力斯凤凰智创科技有限公司申请一项名为“多轴机器人运动轨迹校验方法、装置...
电信运营商开始卖Token,估... 2026年5月17日,中国电信正式推出了全国层面的试商用Token套餐,这标志着运营商的计费模式正从...
史上最大IPO,谁最躺赢? 今年科技IPO的热闹程度是空前的。 Cerebras刚刚在5月14日率先登场,发行价185美元,首日...
当“确定性”出现裂缝:迪拜的枢... 战争降临照片上是一幢写字楼,黑烟正从某一层往外冒,有几层的玻璃窗被完全击碎,窗框还挂着锯齿形的边角—...
视频丨“一部手机走天下” 中国... 从一线城市商圈到县域小店,从夜市摊贩到景区门票,在我们的日常生活中,二维码无处不在,移动支付普及率已...
2026世界电信和信息社会日报... 央广网南宁5月16日消息(记者梁瑜琳)在世界电信和信息社会日即将到来之际,5月15日,2026世界电...
当第一批丁克住进医院,关键时刻... 子女作为父母生命的延续和资源的继承者,自然该承担起养老的重担。而没有子女者住进医院,手术签字、术后付...