设为首页 收藏本站
查看: 1064|回复: 0

[经验分享] 【转】set unused

[复制链接]

尚未签到

发表于 2015-6-17 09:26:50 | 显示全部楼层 |阅读模式
  一、问题
  现场有一张大数据量的分区表,数据量在10G以上。因某种原因需要删除其中的某些字段。如果直接用
  alter table1 drop (column1,column2); 或者
  alter table1 drop column column1;和
  alter table1 drop column column2;  的话,
  需要执行很长时间,这期间该表被锁,会影响到其它应用。
  二、解决方法
  使用set unused,等系统空闲时再drop unused。
  1.
  alter table table1 set unused (column1,column2);
  或者
  alter table table1 set unused column column1;
  alter table table2 set unused column column2;
  2.
  alter table drop unused columns checkpoint 1000;
  三、知识点(set unused的用法)
  原理:清楚掉字典信息(撤消存储空间)不可恢复
   可以使用 SET UNUSED 选项标记一列或者多列不可用。
   使用DROP SET UNUSED 选项删除被被标记为不可用的列。
语法:
   ALTER TABLE table SET UNUSED (COLlist多个) 或者 ALTER TABLE table SET UNUSED COLUMN col单个;
   ALTER TABLE table DROP UNUSED COLUMNS [checkpoint 1000];
set unused不会真地删除字段。
除了alter table drop field外,也可以
alter table set   unused field;
alter table drop unused;
set unused系统开销比较小,速度较快,所以可以先set unuased,然后在系统负载较小时,再drop。如系统负载不大,也可以直接drop。
不管用何种方法,都不会收回空间。
如果你有这个需求,要删除某一个表格上的某些栏位,但是由於这个表格拥有非常大量的资料,如果你在尖峰时间直接执行 ALTER TABLE ABC DROP (COLUMN);可能会收到 ORA-01562 - failed to extend rollback segment number string,
这是因为在这个删除栏位的过程中你可能会消耗光整个RBS,造成这样的错误出现,因此这样的做法并不是一个好方法,就算你拼命的加大RBS空间来应付这个问题,也不会是个好主意。
        我的建议做法:
        1>
        CREATE TABLE T1 (A NUMBER,B NUMBER);
        SQL> begin 2 for i in 1 …… 100000 3 loop 4 insert into t1 values (i,100);5 end loop;6 commit;7 end;
        SQL> select count(*) from t1;
        COUNT(*)
        100000
        2>
        SQL> ALTER TABLE T1 SET UNUSED COLUMN A CASCADE CONSTRAINTS;
        不要马上drop column,应该先set unused让column无法使用,避开系统尖峰时间再来处理删除栏位里的资料,要注意的是一但你set unused column,这个栏位是无法再回复使用的。
        3>
        重点来了,若你的栏位有一百万笔资料,我们应该避免一次写入那么多的undo log,所以我准备每删除一千笔资料就commit一次。
        SQL> alter table t1 drop unused columns checkpoint 1000;
        Table altered.
        在离峰的时间进行这样的动作,应该可以避免 ORA-01562 的错误发生。


  刚才有个人问我如何修复被设置为UNUSED的字段,我考虑了一下,以下的方法可以恢复(以下步骤执行前要做好备份),没有经验的DBA不要轻易尝试。
  1、创建实验表TTTA
  SQL> CREATE TABLE TTTA ( A INTEGER,B INTEGER,C VARCHAR2(10),D INTEGER);
  表已创建。
  SQL> INSERT INTO TTTA VALUES (1,2,'3',4);
  已创建 1 行。
  SQL> INSERT INTO TTTA VALUES (2,3,'4',5);
  已创建 1 行。
  SQL> COMMIT;
  提交完成。
ALTER TABLE TTTA SET UNUSED COLUMN C;
  2、以下进行恢复
SQL> SELECT OBJ# FROM OBJ$ WHERE NAME='TTTA';
        OBJ#
----------
     32067
  SELECT COL#,INTCOL#,NAME FROM COL$ WHERE OBJ#=32067;
      COL#    INTCOL# NAME
---------- ---------- ------------------------------
         1          1 A
         2          2 B
         0          3 SYS_C00003_08031720:09:55$   被UNUSED的字段
         3          4 D
  SQL> SELECT COLS FROM TAB$ WHERE OBJ#=32067;
        COLS
----------
         3      ------字段数变为3了
  
  
SQL> UPDATE COL$ SET COL#=INTCOL# WHERE OBJ#=32067;
  已更新4行。
  SQL> UPDATE TAB$ SET COLS=COLS+1 WHERE OBJ#=32067;
  已更新 1 行。
  UPDATE COL$ SET NAME='C' WHERE OBJ#=32067 AND COL#=3;
  UPDATE COL$ SET PROPERTY=0 WHERE OBJ#=32067;
SQL> COMMIT;
  3、重启数据库
SQL> SELECT * FROM SCOTT.TTTA;
           A          B C                   D
---------- ---------- ---------- ----------
         1          2 3                   4
         2          3 4                   5
  恢复完成

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-78065-1-1.html 上篇帖子: Oracle HAVING子句 下篇帖子: 重要oracle 热备份和恢复#ocp试验#|归档模式打开|
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表