zoukankan      html  css  js  c++  java
  • ORA-10635: Invalid segment or tablespace type

    上周星期天在迁移数据时,碰到了ORA-10635: Invalid segment or tablespace type 错误,当时的操作环境如下:

    操作系统版本:

    [oracle@xxxxx scripts]$ more /etc/issue
    Red Hat Enterprise Linux ES release 4 (Nahant Update 6)

    数据库版本  :

    SQL> select * from v$version;

     

    BANNER
    ----------------------------------------------------------------
    Oracle Database 10g Release 10.2.0.4.0 - 64bit Production
    PL/SQL Release 10.2.0.4.0 - Production
    CORE 10.2.0.4.0 Production
    TNS for Linux: Version 10.2.0.4.0 - Production
    NLSRTL Version 10.2.0.4.0 - Production

    把一批表2011年的数据迁移到历史表归档时,由于是DELETE操作,为了降低这批表的高水位线,执行下面操作。

    ALTER TABLE TABLE_NAME ENABLE ROW MOVEMENT ;
    ALTER TABLE TABLE_NAME SHRINK SPACE;

    结果报如下错误:

    image

    ORA-10635: Invalid segment or tablespace type

    检查这些表的表空间的SEGMENT_SPACE_MANAGEMENT的值,发现它是手动段空间管理,而不是自动段空间管理(ASSM)

    SELECT TABLESPACE_NAME, SEGMENT_SPACE_MANAGEMENT FROM DBA_TABLESPACES WHERE TABLESPACE_NAME= 'TABLESPACE_NAME'

    ------------------------------------------------------------------------
    xxxxxxx        MANUAL

    从10g开始,ORACLE开始提供Shrink的命令,假如我们的表空间中支持自动段空间管理 (ASSM),就可以使用这个特性缩小段,即降低HWM。这里需要强调一点,10g的这个新特性,仅对ASSM表空间有效,否则会报 ORA-10635: Invalid segment or tablespace type。

    其实会导致这个错误的原因还有其它一些:

    1. You cannot specify this clause for a cluster, a clustered table, or any object with a LONG column.
    2. Segment shrink is not supported for tables with function-based indexes or bitmap join indexes.
    3. This clause does not shrink mapping tables of index-organized tables,even if you specify CASCADE.参见后面的测试
    4. You cannot specify this clause for a compressed table.
    5. You cannot shrink a table that is the master table of an ON COMMIT materialized view. Rowid materialized views must be rebuilt after the shrink operation.

    1. 对cluster,cluster table,或具有Long类型列的对象不起作用。
    2. 不支持具有function-based indexes 或 bitmap join indexes的表
    3. 不支持mapping 表或index-organized表。
    4. 不支持compressed 表

    5: 不支持是ON COMMIT物化视图中的主表

    Shrink operations can be performed only on segments in locally managed tablespaces with automatic segment space management (ASSM). Within an ASSM tablespace, all segment types are eligible for online segment shrink except these:

    • IOT mapping tables

    • Tables with rowid based materialized views

    • Tables with function-based indexes

  • 相关阅读:
    NO29 用户提权sudo配置文件详解实践--志行为审计
    NO28 第四关考试题
    NO27 定时任务
    NO26 Linux的文件权限--chmod--Linux删除文件说明--suid--sgid
    NO25 三剑客之SED行天下
    NO24 第三关--企业面试题
    gcc编译错误表
    C++的精髓——虚函数
    gcc 优化选项 -O1 -O2 -O3 -Os 优先级,-fomit-frame-pointer
    正确使用#include和前置声明(forward declaration)
  • 原文地址:https://www.cnblogs.com/kerrycode/p/3196807.html
Copyright © 2011-2022 走看看