oracle大数据表复制备份个人经验
数据库  /  管理员 发布于 4年前   865
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.注意内容
123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..路人 在
php中使用hyperf框架调用讯飞星火大模型实现国内版chatgpt功能示例中评论 教程很详细,如果加个前端chatgpt对话页面就完美了..Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号