postgresql – 如何复制巨大的postgres表?

postgresql – 如何复制巨大的postgres表?,第1张

概述我有巨大的postgres表(10GB数据–160M记录).表是静态的,并且没有执行写 *** 作.我想复制它,执行写入,重新索引它,然后使用单个快速事务删除旧的并将新的重命名为原始名称. 复制这样巨大的表的最快方法是什么? 通常,复制表的最快方法是: CREATE TABLE table2 AS SELECT * FROM table1; 并行INSERT可能更快,但只有非常快的磁盘子系统(当数据在许多 我有巨大的postgres表(10GB数据–160M记录).表是静态的,并且没有执行写 *** 作.我想复制它,执行写入,重新索引它,然后使用单个快速事务删除旧的并将新的重命名为原始名称.

复制这样巨大的表的最快方法是什么?

通常,复制表的最快方法是:
CREATE table table2 AS SELECT * FROM table1;

并行INSERT可能更快,但只有非常快的磁盘子系统(当数据在许多驱动器上交错时).否则这会慢一些.

完成修改table2后,可以使用新名称:

BEGIN;DROP table table1;ALTER table table2 REname TO table1;COMMIT;

DROP table命令需要一个独占锁,它以您可能想要预期的方式影响并发读取器:

> DROP将等待来自其他事务的表上的任何挂起读取完成.
>在此期间尝试读取该表的任何新事务都将等待,然后失败,因为原始table1不再存在.该错误看起来像“无法打开与OID oID的关系”

为避免出现第二个问题,您可以将table1重命名为old_table1而不是将其删除,然后在这些读取器完成后将其放在事务之外的稍后.所以上面的顺序将成为:

BEGIN;ALTER table table1 REname TO old_table1;ALTER table table2 REname TO table1;COMMIT;...DROP table old_table1;
总结

以上是内存溢出为你收集整理的postgresql – 如何复制巨大的postgres表?全部内容,希望文章能够帮你解决postgresql – 如何复制巨大的postgres表?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1168305.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存