该方法使用CREATE TEMP TABLE ... AS语句创建原始表的临时表,然后截断原始表并从临时表填充原始表,以完成原始表的深层复制。
在新建表需要保留父表的主键属性,或如果父表具有依赖项的情况下,建议使用此方法。
操作步骤
步骤1 使用CREATE TEMP TABLE AS语句创建表customer_t的临时表副本customer_t_temp。
gbase=# CREATE TEMP TABLE customer_t_temp AS SELECT * FROM customer_t;
与使用永久表相比,使用临时表可以提高性能,但存在丢失数据的风险。临时表只在当前会话可见,本会话结束后将自动删除。如果数据丢失是不可接受的,请使用永久表。
步骤2 截断当前表customer_t。
gbase=# TRUNCATE customer_t;