SQL – 优雅复制树结构

导读:本篇文章讲解 SQL – 优雅复制树结构,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

需求:

复制树形结构数据


问题描述

老的做法:将数据去读到内存中,修改部分数据,然后将数据插入到数据库;

问题:

  • 如果有大量的数据,产生多次IO交互
  • 如果在一次读取所有的数据,分批插入,有可能把应用内存打爆;

解决方案:

使用 insert select 的语法,直接在数据库中进行复制操作,变免多个io和内存消耗

一、前置条件

需要增加copyId字段,记录被父子的数据id,用来协助更新父子关系

二、 复制数据

注意:pgsql 使用uuid需要先创建“uuid-ossp”函数

create extensionifnotexists"uuid-ossp";
INSERT INTO sys_gdc_sqlconf ( ID, pid, copyid ) 
SELECT
uuid_generate_v4(),
pid,
seq,
ID 
FROM
    sys_gdc_sqlconf

三、更新父子关系

UPDATE 
sys_gdc_sqlconf t1 
SET pid = t2.ID 
FROM
    sys_gdc_sqlconf t2 
WHERE
    t1.pid = t2.copyid

SQL - 优雅复制树结构

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/117210.html

(1)
seven_的头像seven_bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!