PostgreSQL日常运维:在PostgreSQL中启用、禁用和验证外键约束

在数据迁移过程中,为了解决因表间数据依赖导致的数据加载失败,本文介绍了如何在PostgreSQL中禁用、启用外键约束及验证约束。禁用约束需要超级用户权限,可以通过删除并重新创建外键、更新系统表或使用约束延迟生效的方法来处理外键约束问题。

在PostgreSQL中启用、禁用和验证外键约束

近期在做数据迁移的过程中,遇到有外键约束的表由于表之间数据的依赖关系和数据的导入顺序导致数据加载失败,因此记录了一下关于这类问题的解决思路。

-- 建表
create table t1 ( a serial primary key, b text,c date);

create table t2 ( a serial primary key,b int references t1(a),c text);

-- 违反外键约束的插入,测试数据
COPY public.t2 (a, b, c) FROM stdin;
1	1	aa
2	2	aa
\.

COPY public.t1 (a, b, c) FROM stdin;
1	aa	2020-06-24
2	bb	2020-06-24
\.

psql:b.sql:26: ERROR:  insert or update on table "t2" violates foreign key constraint "t2_b_fkey"
DETAIL:  Key (b)=(1) is not present in table "t1".

因为此时数据本身并没有问题,只是当前恢复表数据时候顺序导致的报错,所以此时我们可以首先禁用t2表上的外键约束并在加载对其进行验证。

test=# alter t
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值