需求:
复制树形结构数据
问题描述
老的做法:将数据去读到内存中,修改部分数据,然后将数据插入到数据库;
问题:
- 如果有大量的数据,产生多次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
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/117210.html