oracle大数据表复制备份个人经验
数据库  /  管理员 发布于 2年前   477
create table user2.LDM_table1 nologging parallel (DEGREE 16) AS SELECT * FROM user1.LDM_table1;
truncate table user1.LDM_table1;
alter table user1.LDM_table1 nologging; alter session enable parallel dml; insert /*+append parallel*/ into user1.LDM_table1 SELECT/*+parallel*/ * FROM user2.LDM_table1;COMMITalter table user1.LDM_table1 logging;;
create table user1.LDM_table1 nologging parallel (DEGREE 16) AS SELECT * FROM user2.LDM_table1;
create bitmap index user1.INDEX_LDM_table1_RQ on user1.LDM_table1 (RQ)parallel 24 local;
exec dbms_stats.gather_table_stats('USER1','LDM_TABLE1,CASCADE=>true,estimate_percent=>10,method_opt=>'for all columns size auto',degree=>16);
create table user1.LDM_table1( aaa, bbb, ccc, .... )partition by range (N_DM)( partition P00000000000 values less than (' 5500000') tablespace TS_DAT_LDM pctfree 10 initrans 1 maxtrans 255 storage ( initial 160K next 1M minextents 1 maxextents unlimited ), partition P 5500000 values less than ('5501000') tablespace TS_DAT_LDM pctfree 10 initrans 1 maxtrans 255 storage ( initial 160K next 1M minextents 1 maxextents unlimited ), ........)select aaa,bbb,ccc,.....from user2.LDM_table1;6.有时候需要将表user2.LDM_table1中的部分数据提交到表user1.LDM_table1中,如果采用上述3中的方法会觉得有些慢,可以采用分部提交或者就循环提交,每次提交100万,直至提交完毕,具体sql如下
declare cursor cur is select /*+parallel(16)*/* from user2.LDM_table1; type rec is table of cur%rowtype; recs rec;begin execute immediate 'alter table user1.LDM_table1 nologging'; execute immediate 'alter session enable parallel dml'; open cur; while (true) loop fetch cur bulk collect into recs limit 1000000; forall i in 1 .. recs.count insert /*+append parallel(8)*/into user1.LDM_table1 values recs (i); commit; exit when cur%notfound; end loop; close cur; execute immediate 'alter table user1.LDM_table1 logging';end;/7.如果想删除大表user1.LDM_table1中的部分数据,比如从几亿数据中删除1000万,可能采用delete方法比较慢,所以我们可以采用循环删除的方法,具体sql如下:
declare v_cnt NUMBER:=0;BEGIN LOOP DELETE FROM user1.LDM_table1 WHERE y_dm LIKE '10025%' AND ROWNUM<=10000; v_cnt:=SQL%ROWCOUNT; COMMIT; EXIT WHEN v_cnt<=0; END LOOPEND;/--加并行快点
declare v_cnt NUMBER:=0;BEGIN execute immediate 'alter table user1.LDM_table1 nologging'; execute immediate 'alter session enable parallel dml'; LOOP DELETE/*+PARALLEL(16)*/ FROM user1.LDM_table1 WHERE y_dm LIKE '10025%' AND ROWNUM<=10000; v_cnt:=SQL%ROWCOUNT; COMMIT; EXIT WHEN v_cnt<=0; END LOOPEND;/8.注意内容
博主 在
2023年国务院办公厅春节放假通知:1月21日起休7天中评论 @ xiaoB 你只管努力,剩下的叫给天意;天若有情天亦老,..xiaoB 在
2023年国务院办公厅春节放假通知:1月21日起休7天中评论 会不会春节放假后又阳一次?..BUG4 在
你翻墙过吗?国内使用vpn翻墙可能会被网警抓,你需了解的事中评论 不是吧?..博主 在
go语言+beego框架中获取get,post请求的所有参数中评论 @ t1 直接在router.go文件中配就ok..Jade 在
如何在MySQL查询中获得当月记录中评论 Dear zongscan.com team, We can skyroc..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号