作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我尝试将一个数据库转储到另一个数据库。表中有一些重复的唯一值。当 pg_dump 尝试将此项添加到 db 时,它抛出错误并退出。错误就像;
ERROR: duplicate key value violates unique constraint "test_table_pkey"
DETAIL: Key (pktable)=(col11) already exists.
CONTEXT: COPY test_table, line 1: "col11 col12"
我的 table 是;
Column | Type | Modifiers
-------------+-----------------------+-----------
pktable | text | not null
source | text | not null
Indexes:
"test_table_pkey" PRIMARY KEY, btree (pktable)
我的命令是;
pg_dump -U postgres -v --data-only <db_name> | psql -U postgres -h <remote_host> -d <db_name>
我希望 pg_dump 跳过重复的唯一值并继续转储操作。我该怎么做?
最佳答案
我认为这条规则可以帮助你:
CREATE RULE "my_table_on_duplicate_ignore" AS ON INSERT TO "my_table"
WHERE EXISTS(SELECT 1 FROM my_table
WHERE (pk_col_1, pk_col_2)=(NEW.pk_col_1, NEW.pk_col_2))
DO INSTEAD NOTHING;
基本上,如果新插入的行已经在表中,就会触发 INSTEAD NOTHING
。
关于postgresql - 转储数据库时跳过违反唯一约束,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27667581/
我正在为我的应用程序使用 Tank-Auth。我唯一的问题是激活和重置帐户密码。 用于登录、注册、注销;我对这些代码没有问题; $route['login'] = "/auth/login"; $ro
我是一名优秀的程序员,十分优秀!