oracle大数据表复制备份个人经验
数据库  /  管理员 发布于 3年前   682
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.注意内容
路人 在
php中使用hyperf框架调用讯飞星火大模型实现国内版chatgpt功能示例中评论 教程很详细,如果加个前端chatgpt对话页面就完美了..博主 在
科学上网翻墙之v2rayN-Core客户端免费公益节点使用教程中评论 @ mashrdn 多切换几个节点测试,免费ssr是没那么稳..mashrdn 在
科学上网翻墙之v2rayN-Core客户端免费公益节点使用教程中评论 V2rayn免费节点添加上去了,youtobe无法打开网页,是怎么回事..张伟 在
科学上网翻墙之v2rayN-Core客户端免费公益节点使用教程中评论 3q!有用,不过免费节点隔天就要去git上复制新的导进去..博主 在
科学上网翻墙访问Google , 上外网神器佛跳墙VPN(永久免费)使用流程步骤中评论 该篇教程已不能用了,告知大家,免的老有老铁问我!..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号