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

news/2024/10/18 1:29:56/

文章目录

    • openGauss学习笔记-171 openGauss 数据库运维-备份与恢复-导入数据-深层复制
      • 171.1 使用CREATE TABLE执行深层复制
        • 171.1.1 操作步骤
      • 171.2 使用CREATE TABLE LIKE执行深层复制
        • 171.2.1 操作步骤
      • 171.3 通过创建临时表并截断原始表来执行深层复制
        • 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。

    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语句向副本填充原始表中的数据。

    INSERT INTO customer_t_copy (SELECT * FROM customer_t);
    
  3. 删除原始表。

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

    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。

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

    INSERT INTO customer_t_copy (SELECT * FROM customer_t);
    
  3. 删除原始表。

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

    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。

    CREATE TEMP TABLE customer_t_temp AS SELECT * FROM customer_t;
    

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

  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;
    

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

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

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

图片


http://www.ppmy.cn/news/1279125.html

相关文章

【智慧办公】如何让智能会议室的电子标签实现远程、批量更新信息?东胜物联网硬件网关让解决方案更具竞争力

近年来,为了减少办公耗能、节能环保、降本增效,越来越多的企业开始从传统的办公模式转向智慧办公。 以智能会议室为例,会议是企业业务中不可或缺的一部分,但在传统办公模式下,一来会议前行政人员需要提前准备会议材料…

python调用GPT API

每次让gpt给我生成一个调用api的程序时,他经常会调用以前的一些api的方法,导致我的程序运行错误,所以这期记录一下使用新的方法区调用api 参考网址 Migration Guide,这里简要地概括了一下新版本做了哪些更改 OpenAI Python API l…

golang的postgreSQL框架go-pg常用操作汇总

增删改查一应俱全;如果有没列出来的,请留言作者补上。 收藏备忘,快速查阅! 目录 查询指定列 举例1:根据主键直接查询 举例2:查询指定单列 举例3:查询指定多列 多条件查询 whereIn查询 原…

使用C语言将ASCII明文编码为GSM短信体格式

一、背景介绍 GSM(Global System for Mobile Communications)是全球移动通信系统的简称,而GSM 03.38是GSM系统中用于短信编码的标准。GSM 03.38字符集采用7-bit编码,与ASCII的8-bit编码有所不同。为了将ASCII编码的文本转换为GSM…

uniapp使用colorUI

colorUI 微动画 | ColorUI 使用文档 1&#xff1a;把colorui里三个文件复制到自己项目中去 App.vue </script> <style> import url(colorui/icon.css); import url(colorui/main.css); import url("colorui/animation.css");-webkit-keyframes show {…

Web前端-JavaScript(内置对象)

文章目录 1 内置对象1.1 概述1.2 Math对象1.3 Date对象1.4 Array对象数组判断添加删除数组排序数组转字符串数组索引方法清空数组其它方法 1.5 String对象字符串的不可变根据字符返回位置根据位置返回字符字符串操作方法替换方法分割方法 2 数据类型存储方式2.1 数据类型分类&a…

对数函数求导

方法 一般形 复合型 复杂复合型

使用OpenCV4实现工业缺陷检测的六种方法

目录 1 机器视觉2 缺陷检测3 工业上常见缺陷检测方法 1 机器视觉 机器视觉是使用各种工业相机&#xff0c;结合传感器跟电气信号实现替代传统人工&#xff0c;完成对象识别、计数、测量、缺陷检测、引导定位与抓取等任务。其中工业品的缺陷检测极大的依赖人工完成&#xff0c;…