暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

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

墨天轮 2019-10-12
1288

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

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

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

操作步骤

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

    1
    CREATE TABLE customer_t_temp AS SELECT * FROM customer_t;
    
    说明:

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

  • 截断当前表customer_t。

    1
    TRUNCATE customer_t;
    

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

    1
    INSERT INTO customer_t (SELECT * FROM customer_t_temp);
    

  • 删除临时表副本customer_t_temp。

    1
    DROP TABLE customer_t_temp;
    


查看更多:华为GaussDB 200 深层复制
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论