• 如何drop大表的中不用的字段 set unused column


    转自 http://foxmile.blog.163.com/blog/static/81169805201143191957184/

    我 们要删除表中不用的字段,如果直接drop column,对于大表,进行DDL操作的时间会比较长,会严重阻塞DML语句,导致应用服务器crash,通常的做法是先set unused column column_name 或者 set unused column_name,column_name...,然后再利用停机时间做alter table table_name drop unused columns。

    做如下实验:
    SQL> select table_name,num_rows From all_tables Where table_name = 'TABA';
     
    TABLE_NAME                       NUM_ROWS
    ------------------------------ ----------
    TABA                                      99724223
    该表99724223条数据,是分区表按月分50个分区,直接drop字段BTYPE预计需要30分钟。
    首先将该字段设置为unused:
    SQL> set time on timing on
    9:18:28 SQL> 
    9:24:59 SQL> 
    9:24:59 SQL> 
    9:24:59 SQL> ALTER TABLE user1.TABASET set UNUSED (BTYPE);
     
    Table altered
     
    这样的话,有新的数据,数据库不会再给该字段分配存储空间。我们可以找系统空闲的时候删除该列。
    9:27:23 SQL> alter table TABA drop unused Columns;
     
    Table altered
     
    Executed in 1260.344 seconds
     
  • 相关阅读:
    java方式实现堆排序
    java方式实现归并排序
    用java方式实现快速排序
    Linux中crontab定时任务
    TCP/IP网络协议初识
    github设置添加ssh
    IDM下载工具使用
    Java程序在内存中运行详解
    GitHub的高级搜索方式
    深入理解JavaScript中的堆与栈 、浅拷贝与深拷贝
  • 原文地址:https://www.cnblogs.com/princessd8251/p/3425808.html
Copyright © 2020-2023  润新知