postgresql – 如何复制巨大的postgres表?
发布时间:2020-12-13 16:22:58 所属栏目:百科 来源:网络整理
导读:我有巨大的postgres表(10GB数据–160M记录).表是静态的,并且没有执行写操作.我想复制它,执行写入,重新索引它,然后使用单个快速事务删除旧的并将新的重命名为原始名称. 复制这样巨大的表的最快方法是什么? 通常,复制表的最快方法是: CREATE TABLE table2 AS
我有巨大的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重命名为old_table1而不是将其删除,然后在这些读取器完成后将其放在事务之外的稍后.所以上面的顺序将成为: BEGIN; ALTER TABLE table1 RENAME TO old_table1; ALTER TABLE table2 RENAME TO table1; COMMIT; ... DROP TABLE old_table1; (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |