• 技术文章 >数据库 >Oracle

    oracle怎么修改索引

    青灯夜游青灯夜游2022-01-25 17:10:19原创274

    oracle修改索引的方法:1、使用“alter index 旧索引名 rename to 新索引名;”语句重命名索引;2、使用“drop index”语句删除原来的索引,再使用“CREATE INDEX”语句根据需要创建一个同名的索引。

    本教程操作环境:Windows7系统、Oracle 11g版、Dell G3电脑。

    说明

      1)索引是数据库对象之一,用于加快数据的检索,类似于书籍的索引。在数据库中索引可以减少数据库程序查询结果时需要读取的数据量,类似于在书籍中我们利用索引可以不用翻阅整本书即可找到想要的信息。

      2)索引是建立在表上的可选对象;索引的关键在于通过一组排序后的索引键来取代默认的全表扫描检索方式,从而提高检索效率

      3)索引在逻辑上和物理上都与相关的表和数据无关,当创建或者删除一个索引时,不会影响基本的表;

      4)索引一旦建立,在表上进行DML操作时(例如在执行插入、修改或者删除相关操作时),oracle会自动管理索引,索引删除,不会对表产生影响

      5)索引对用户是透明的,无论表上是否有索引,sql语句的用法不变

      6)oracle创建主键时会自动在该列上创建索引

    索引原理

    1. 若没有索引,搜索某个记录时(例如查找name='wish')需要搜索所有的记录,因为不能保证只有一个wish,必须全部搜索一遍

    2. 若在name上建立索引,oracle会对全表进行一次搜索,将每条记录的name值哪找升序排列,然后构建索引条目(name和rowid),存储到索引段中,查询name为wish时即可直接查找对应地方

    3.创建了索引并不一定就会使用,oracle自动统计表的信息后,决定是否使用索引,表中数据很少时使用全表扫描速度已经很快,没有必要使用索引

    索引使用(创建、修改、删除、查看)

    1.创建索引语法

    CREATE [UNIQUE] | [BITMAP] INDEX index_name  --unique表示唯一索引
    ON table_name([column1 [ASC|DESC],column2    --bitmap,创建位图索引
    [ASC|DESC],…] | [express]) [TABLESPACE tablespace_name]
    [PCTFREE n1]                                 --指定索引在数据块中空闲空间
    [STORAGE (INITIAL n2)]
    [NOLOGGING]                                  --表示创建和重建索引时允许对表做DML操作,默认情况下不应该使用
    [NOLINE]
    [NOSORT];                                    --表示创建索引时不进行排序,默认不适用,如果数据已经是按照该索引顺序排列的可以使用

    2.修改索引

    1)重命名索引

    alter index index_sno rename to bitmap_index;

    2) 合并索引(表使用一段时间后在索引中会产生碎片,此时索引效率会降低,可以选择重建索引或者合并索引,合并索引方式更好些,无需额外存储空间,代价较低)

    alter index index_sno coalesce;

    3)重建索引

      方式一:删除原来的索引,再根据需要创建一个同名的索引。

      方式二:

    alter index index_sno rebuild;

    3.删除索引

    drop index index_sno;

    4.查看索引

    select index_name,index-type, tablespace_name, uniqueness from all_indexes where table_name ='tablename'; -- eg: 
    create index index_sno on student('name'); select * from all_indexes where table_name='student';

    推荐教程:《Oracle教程

    以上就是oracle怎么修改索引的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:oracle 修改索引
    上一篇:oracle分页查询原理是什么 下一篇:oracle怎样修改用户

    相关文章推荐

    • 怎样执行oracle存储过程• oracle怎样修改字符集• oracle怎样递归查询子节点• oracle是应用软件吗• oracle存储过程的参数类型有哪些• 怎样删除oracle用户• oracle中触发器和存储过程是什么

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网