openGauss学习笔记-171 openGauss 数据库运维-备份与恢复-导入数据-深层复制

文章目录

    • [openGauss学习笔记-171 openGauss 数据库运维-备份与恢复-导入数据-深层复制](#openGauss学习笔记-171 openGauss 数据库运维-备份与恢复-导入数据-深层复制)
      • [171.1 使用CREATE TABLE执行深层复制](#171.1 使用CREATE TABLE执行深层复制)
        • [171.1.1 操作步骤](#171.1.1 操作步骤)
      • [171.2 使用CREATE TABLE LIKE执行深层复制](#171.2 使用CREATE TABLE LIKE执行深层复制)
        • [171.2.1 操作步骤](#171.2.1 操作步骤)
      • [171.3 通过创建临时表并截断原始表来执行深层复制](#171.3 通过创建临时表并截断原始表来执行深层复制)
        • [171.3.1 操作步骤](#171.3.1 操作步骤)

openGauss学习笔记-171 openGauss 数据库运维-备份与恢复-导入数据-深层复制

171.1 使用CREATE TABLE执行深层复制

该方法使用CREATE TABLE语句创建原始表的副本,将原始表的数据填充至副本并重命名副本,完成原始表的复制。

在创建新表时,可以指定表以及列属性,比如主键。

171.1.1 操作步骤

执行如下步骤对表customer_t进行深层复制。

  1. 使用CREATE TABLE语句创建表customer_t的副本customer_t_copy。

    sql 复制代码
    CREATE TABLE customer_t_copy
    ( c_customer_sk             integer,   
      c_customer_id             char(5),    
      c_first_name              char(6),    
      c_last_name               char(8) 
    ) ;
  2. 使用INSERT INTO...SELECT语句向副本填充原始表中的数据。

    sql 复制代码
    INSERT INTO customer_t_copy (SELECT * FROM customer_t);
  3. 删除原始表。

    sql 复制代码
    DROP TABLE customer_t;
  4. 使用ALTER TABLE语句将副本重命名为原始表名称。

    css 复制代码
    ALTER TABLE customer_t_copy RENAME TO customer_t;

171.2 使用CREATE TABLE LIKE执行深层复制

该方法使用CREATE TABLE LIKE语句创建原始表的副本,将原始表的数据填充至副本并重命名副本,完成原始表的复制。该方法不继承父表的主键属性,您可以使用ALTER TABLE语句来添加它们。

171.2.1 操作步骤
  1. 使用CREATE TABLE LIKE语句创建表customer_t的副本customer_t_copy。

    sql 复制代码
    CREATE TABLE customer_t_copy (LIKE customer_t);
  2. 使用INSERT INTO...SELECT语句向副本填充原始表中的数据。

    sql 复制代码
    INSERT INTO customer_t_copy (SELECT * FROM customer_t);
  3. 删除原始表。

    sql 复制代码
    DROP TABLE customer_t;
  4. 使用ALTER TABLE语句将副本重命名为原始表名称。

    css 复制代码
    ALTER TABLE customer_t_copy RENAME TO customer_t;

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

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

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

171.3.1 操作步骤
  1. 使用CREATE TABLE AS语句创建表customer_t的临时表副本customer_t_temp。

    sql 复制代码
    CREATE TEMP TABLE customer_t_temp AS SELECT * FROM customer_t;

    说明:

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

  2. 截断当前表customer_t。

    cpp 复制代码
    TRUNCATE customer_t;
  3. 使用INSERT INTO...SELECT语句从副本中向原始表中填充数据。

    sql 复制代码
    INSERT INTO customer_t (SELECT * FROM customer_t_temp);
  4. 删除临时表副本customer_t_temp。

    sql 复制代码
    DROP TABLE customer_t_temp;

👍 点赞,你的认可是我创作的动力!

⭐️ 收藏,你的青睐是我努力的方向!

✏️ 评论,你的意见是我进步的财富!

相关推荐
云和数据.ChenGuang8 分钟前
Django 应用安装脚本 – 如何将应用添加到 INSTALLED_APPS 设置中 原创
数据库·django·sqlite
woshilys36 分钟前
sql server 查询对象的修改时间
运维·数据库·sqlserver
Hacker_LaoYi37 分钟前
SQL注入的那些面试题总结
数据库·sql
建投数据2 小时前
建投数据与腾讯云数据库TDSQL完成产品兼容性互认证
数据库·腾讯云
Hacker_LaoYi3 小时前
【渗透技术总结】SQL手工注入总结
数据库·sql
岁月变迁呀3 小时前
Redis梳理
数据库·redis·缓存
独行soc3 小时前
#渗透测试#漏洞挖掘#红蓝攻防#护网#sql注入介绍06-基于子查询的SQL注入(Subquery-Based SQL Injection)
数据库·sql·安全·web安全·漏洞挖掘·hw
你的微笑,乱了夏天3 小时前
linux centos 7 安装 mongodb7
数据库·mongodb
工业甲酰苯胺3 小时前
分布式系统架构:服务容错
数据库·架构
独行soc4 小时前
#渗透测试#漏洞挖掘#红蓝攻防#护网#sql注入介绍08-基于时间延迟的SQL注入(Time-Based SQL Injection)
数据库·sql·安全·渗透测试·漏洞挖掘