openGauss学习笔记-171 openGauss 数据库运维-备份与恢复-导入数据-深层复制
文章目录
openGauss学习笔记-171 openGauss 数据库运维-备份与恢复-导入数据-深层复制
171.1 使用CREATE TABLE执行深层复制
该方法使用CREATE TABLE语句创建原始表的副本,将原始表的数据填充至副本并重命名副本,完成原始表的复制。
在创建新表时,可以指定表以及列属性,比如主键。
171.1.1 操作步骤
执行如下步骤对表customer_t进行深层复制。
-
使用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) ) ;
-
使用INSERT INTO…SELECT语句向副本填充原始表中的数据。
INSERT INTO customer_t_copy (SELECT * FROM customer_t);
-
删除原始表。
DROP TABLE customer_t;
-
使用ALTER TABLE语句将副本重命名为原始表名称。
ALTER TABLE customer_t_copy RENAME TO customer_t;
171.2 使用CREATE TABLE LIKE执行深层复制
该方法使用CREATE TABLE LIKE语句创建原始表的副本,将原始表的数据填充至副本并重命名副本,完成原始表的复制。该方法不继承父表的主键属性,您可以使用ALTER TABLE语句来添加它们。
171.2.1 操作步骤
-
使用CREATE TABLE LIKE语句创建表customer_t的副本customer_t_copy。
CREATE TABLE customer_t_copy (LIKE customer_t);
-
使用INSERT INTO…SELECT语句向副本填充原始表中的数据。
INSERT INTO customer_t_copy (SELECT * FROM customer_t);
-
删除原始表。
DROP TABLE customer_t;
-
使用ALTER TABLE语句将副本重命名为原始表名称。
ALTER TABLE customer_t_copy RENAME TO customer_t;
171.3 通过创建临时表并截断原始表来执行深层复制
该方法使用CREATE TABLE AS语句创建原始表的临时表,然后截断原始表并从临时表填充它完成原始表的深层复制。
在新建表需要保留父表的主键属性,或如果父表具有依赖项的情况下,建议使用此方法。
171.3.1 操作步骤
-
使用CREATE TABLE AS语句创建表customer_t的临时表副本customer_t_temp。
CREATE TEMP TABLE customer_t_temp AS SELECT * FROM customer_t;
说明:
与使用永久表相比,使用临时表可以提高性能,但存在丢失数据的风险。临时表只在当前会话可见,本会话结束后将自动删除。如果数据丢失是不可接受的,请使用永久表。 -
截断当前表customer_t。
TRUNCATE customer_t;
-
使用INSERT INTO…SELECT语句从副本中向原始表中填充数据。
INSERT INTO customer_t (SELECT * FROM customer_t_temp);
-
删除临时表副本customer_t_temp。
DROP TABLE customer_t_temp;
👍 点赞,你的认可是我创作的动力!
?? 收藏,你的青睐是我努力的方向!
?? 评论,你的意见是我进步的财富!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!