VastbaseG100

基于openGauss内核开发的企业级关系型数据库。

Menu

通过创建临时表并截断原始表来执行深层复制

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

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

操作步骤

前置条件: 创建表customer_t并插入数据。

CREATE TABLE customer_t
( c_customer_sk             integer,   
  c_customer_id             char(5),    
  c_first_name              char(6),    
  c_last_name               char(8) 
) ;
INSERT INTO customer_t (c_customer_sk, c_customer_id, c_first_name,c_last_name) VALUES (3769, 5, 'Grace','White');

示例步骤:

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

CREATE TEMP TABLE customer_t_temp AS SELECT * FROM customer_t;

与使用永久表相比,使用临时表可以提高性能,但存在丢失数据的风险。临时表只在当前会话可见,本会话结束后将自动删除。如果数据丢失是不可接受的,请使用永久表。

2、截断原表customer_t。

TRUNCATE customer_t;

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

INSERT INTO customer_t (SELECT * FROM customer_t_temp);

4、删除临时表副本customer_t_temp。

DROP TABLE customer_t_temp;