当前位置:  数据库>oracle

Oracle移动表对索引的影响

    来源: 互联网  发布时间:2017-06-25

    本文导语: 这里主要测试移动表从一个表空间到另一个表空间或者在同同一个表空间做表移动操作对索引的影响。测试中表明:表的移动(move)会直接导致该表中的索引失效,通过重建索引,重新让索引恢复有效可用的状态。以下是简单...

这里主要测试移动表从一个表空间到另一个表空间或者在同同一个表空间做表移动操作对索引的影响。测试中表明:表的移动(move)会直接导致该表中的索引失效,通过重建索引,重新让索引恢复有效可用的状态。以下是简单的测试过程。

---创建测试表:

--查看表结构:

linuxidc@PROD>desc mytest

 Name                                      Null?    Type

 ----------------------------------------- -------- ----------------------------

 NAME                                              VARCHAR2(6)

 CREATED                                            DATE
 

--添加字段:

linuxidc@PROD>alter table mytest add id number(2);

Table altered.

 

--查看表结构:

linuxidc@PROD>desc mytest

 Name                                      Null?    Type

 ----------------------------------------- -------- ----------------------------

 NAME                                              VARCHAR2(6)

 CREATED                                            DATE

 ID                                                NUMBER(2)
 

---创建索引:

linuxidc@PROD>create index ind_mytest on mytest(id);

Index created.

#索引添加成功。

 

--查看表结构:

linuxidc@PROD>desc mytest

 Name                                      Null?    Type

 ----------------------------------------- -------- ----------------------------

 NAME                                              VARCHAR2(6)

 CREATED                                            DATE

 ID                                                NUMBER(2)

 

--查看索引:

linuxidc@PROD>select index_name,table_name,tablespace_name,status

  2  from user_indexes; 

INDEX_NAME      TABLE_NAME      TABLESPACE_NAME STATUS

--------------- --------------- --------------- --------

PK_COL1_COL2    T_IOT          MYSPACE        VALID

IDX_T4          T4              USERS          VALID

IDX_T3          T3              USERS          VALID

IND_MYTEST      MYTEST          USERS          VALID

 

---查看表mytest所在的空间:

linuxidc@PROD>select table_name,tablespace_name

  2  from user_tables

  3  where table_name ='MYTEST';

TABLE_NAME                    TABLESPACE_NAME

------------------------------ ------------------------------

MYTEST                        MYSPACE
 

---把表移动到另外一个表空间:

linuxidc@PROD>alter table mytest move tablespace myspace;

Table altered.

#mytest表已经移动。

 

---此时查看表mytest中的索引状态:

linuxidc@PROD>select index_name,table_name,tablespace_name,status

  2  from user_indexes;

INDEX_NAME      TABLE_NAME      TABLESPACE_NAME STATUS

--------------- --------------- --------------- --------

PK_COL1_COL2    T_IOT          MYSPACE        VALID

IDX_T4          T4              USERS          VALID

IDX_T3          T3              USERS          VALID

IND_MYTEST      MYTEST          USERS          UNUSABLE

#表mytest中的索引已经失效。

 

---重建索引:

linuxidc@PROD>alter index ind_mytest rebuild;

Index altered.

#索引已经重建。

---再次查看索引的信息:

linuxidc@PROD>select index_name,table_name,tablespace_name,status

  2  from user_indexes;

INDEX_NAME      TABLE_NAME      TABLESPACE_NAME STATUS

--------------- --------------- --------------- --------

PK_COL1_COL2    T_IOT          MYSPACE        VALID

IDX_T4          T4              USERS          VALID

IDX_T3          T3              USERS          VALID

IND_MYTEST      MYTEST          USERS          VALID

#索引已经重建,默认情况下索引存放在users表空间里。

 

----移动索引存放的表空间:

linuxidc@PROD>alter table mytest move tablespace myspace;

Table altered.

linuxidc@PROD>select index_name,table_name,tablespace_name,status

  2  from user_indexes;

INDEX_NAME      TABLE_NAME      TABLESPACE_NAME STATUS

--------------- --------------- --------------- --------

PK_COL1_COL2    T_IOT          MYSPACE        VALID

IDX_T4          T4              USERS          VALID

IDX_T3          T3              USERS          VALID

IND_MYTEST      MYTEST          USERS          UNUSABLE
 

---重建索引:

linuxidc@PROD>alter index ind_mytest rebuild tablespace myspace;

Index altered.

 

--再次查看索引的信息:

INDEX_NAME      TABLE_NAME      TABLESPACE_NAME STATUS

--------------- --------------- --------------- --------

PK_COL1_COL2    T_IOT          MYSPACE        VALID

IDX_T4          T4              USERS          VALID

IDX_T3          T3              USERS          VALID

IND_MYTEST      MYTEST          MYSPACE        VALID

#索引已经重建,并已经修改了存放的表空间。

--从上面的测试过程中,发现,移动表或者直接移动索引,都会导致该表中的索引或者移动的索引失效,通过重建rebuild让索引重新正常可用。


    
 
 

您可能感兴趣的文章:

  • Oracle与Mysql主键、索引及分页的区别小结
  • 从Oracle的约束到索引
  • Oracle 9i轻松取得建表和索引的DDL语句
  • Oracle9i取得建表和索引的DDL语句
  • oracle10g全文索引自动同步语句使用方法
  • Oracle建立二进制文件索引的方法
  • 在Oracle 10g中如何获得索引的专家建议
  • Oracle全文索引设置
  • 用Oracle 9i全索引扫描快速访问数据
  • Oracle中如何把表和索引放在不同的表空间里
  • Oracle索引存储关系到数据库的运行效率
  • Oracle索引聚簇表的数据加载
  • 在Oracle中监控和跟踪索引使用情况
  • oracle 索引的相关介绍(创建、简介、技巧、怎样查看) .
  • Oracle中检查是否需要重构索引的sql
  • 轻松取得Oracle 9i建表和索引DDL语句
  • 深度揭露Oracle索引使用中的限制
  • Oracle索引(B*tree与Bitmap)的学习总结
  • oracle 索引不能使用深入解析
  • SQL Server和Oracle数据库索引介绍
  • 在Redhat7.2+Oracle8i如果硬件配置中用P4处理器,对oracle的安装有没有影响(100分)
  • 100分寻求最优化的连接oracle的java程序,请给我讲出理由,我是初学者,在做项目时不想让连接oracle影响我的程序性能
  • Oracle Arraysize设置对于逻辑读的影响实例分析
  • Oracle新技术对Linux的影响
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Oracle移动数据文件到新分区步骤分析
  • Oracle 9i 数据库移动过程详细介绍
  • 在ORACLE移动数据库文件
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • Oracle 数据库开发工具 Oracle SQL Developer
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • Oracle EBS R12 支持 Oracle Database 11g
  • Oracle 10g和Oracle 11g网格技术介绍
  • SCO unix下安装oracle,但没有光盘,请大家推荐一个oracle下载站点(unix版本的)。谢谢!!!!
  • oracle中如何把表中具有相同值列的多行数据合并成一行
  • 请问大家用oracle数据库, 用import oracle.*;下的东西么? 还是用标准库?
  • Oracle 数据库(oracle Database)性能调优技术详解
  • Linux /$ORACLE_HOME $ORACLE_HOME
  • ORACLE日期相关操作
  • Linux系统下Oracle的启动与Oracle监听的启动
  • ORACLE数据库常用字段数据类型介绍
  • 请问在solaris下安装ORACLE,用root用户和用oracle用户安装有什么区别么?
  • Oracle 12c的九大最新技术特性介绍
  • 网间Oracle的连接,远程连接Oracle服务器??


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3