需求:
复制树形结构数据
问题描述
老的做法:将数据去读到内存中,修改部分数据,然后将数据插入到数据库;
问题:
- 如果有大量的数据,产生多次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