华为云云数据库GaussDB通过创建临时表并截断原始表来执行深层复制_云淘科技

该方法使用CREATE TABLE … AS语句创建原始表的临时表,然后截断原始表并从临时表填充它完成原始表的深层复制。

在新建表需要保留父表的主键和外键属性,或如果父表具有依赖项的情况下,建议使用此方法。

操作步骤

使用CREATE TABLE AS语句创建表customer_t的临时表副本customer_t_temp。

1
openGauss=# CREATE TEMP TABLE customer_t_temp AS SELECT * FROM customer_t;

与使用永久表相比,使用临时表可以提高性能,但存在丢失数据的风险。临时表只在当前会话可见,本会话结束后将自动删除。如果数据丢失是不可接受的,请使用永久表。
临时表与普通表的存放位置无差,也可指定tablespace存放。本地临时表应用过多可能会导致系统表膨胀,但总体影响在可接受范围内。

截断当前表customer_t。

1
openGauss=# TRUNCATE customer_t;

使用INSERT INTO…SELECT语句从副本中向原始表中填充数据。

1
openGauss=# INSERT INTO customer_t (SELECT * FROM customer_t_temp);

删除临时表副本customer_t_temp。

1
openGauss=# DROP TABLE customer_t_temp;

父主题: 深层复制

同意关联代理商云淘科技,购买华为云产品更优惠(QQ 78315851)

内容没看懂? 不太想学习?想快速解决? 有偿解决: 联系专家