zoukankan      html  css  js  c++  java
  • oracle大表添加字段default经验分享

    当oracle单表数据量上亿时,对表进行alter table aa add column_1 varchar2(2) defalut 'Y';时,效率及安全性是必须考虑的因素。 

    本帖以2亿的数据表aa举例: 
    alter table aa add column_1 varchar2(2) defalut 'Y'; 
    Table altered 
    Executed in 3600 seconds 
    直接用了一个小时,而且在这过程中是加上了表级锁,也就是连查询都是会被等待的,这是相当危险的操作。

    为什么会这样,原来oracle在执行上面语句时不仅要更新数据字典,还会刷新全部的记录。一次update 2 亿条数据当然需要一个小时,并且还会导致undo空间暴涨。

    如果我们把更新数据字典和更新字段值分开,会不会好一点?
    alter table aa add column_1 varchar2(2); 
    Table altered Executed in 0.016 seconds 
    alter table aa modify column_1 varchar2(2) defalut 'Y'; 
    Table altered
    Executed in 0.003 seconds

    答案是快100万倍,那效果呢?经测试发现在第二种方法不会更新以前的数据,我们可以自己写一个匿名块循环update,一次commit 10000条,达到效率与安全的完美结合。 

    结论:alter table add 语句加上defalut时会刷新存量数据并产生表级锁,需慎用。特别是大表,生产环境,业务产生期间就应该禁止此操作。
    改为add table add不带缺省值,接着来个alter table aa modify column_1 varchar2(2) defalut 'Y';更新存量数据可放到业务较少的凌晨跑。
     
     http://blog.itpub.net/29827022/viewspace-1593139/
  • 相关阅读:
    BZOJ 1101 莫比乌斯函数+分块
    BZOJ 2045 容斥原理
    BZOJ 4636 (动态开节点)线段树
    BZOJ 2005 容斥原理
    BZOJ 2190 欧拉函数
    BZOJ 2818 欧拉函数
    BZOJ 3123 主席树 启发式合并
    812. Largest Triangle Area
    805. Split Array With Same Average
    794. Valid Tic-Tac-Toe State
  • 原文地址:https://www.cnblogs.com/future2012lg/p/6183335.html
Copyright © 2011-2022 走看看