oracle中建立索引有什么用,什么时候使用索引
导读:相信很多人对“oracle中建立索引有什么用,什么时候使用索引”都不太了解,下面小编为你详细解释一下这个问题,希望对你有一定的帮助             在oracle中,索引是一种供服务器在表中快速查找一个行的数据库结构,是建立在表的一...
    相信很多人对“oracle中建立索引有什么用,什么时候使用索引”都不太了解,下面小编为你详细解释一下这个问题,希望对你有一定的帮助在oracle中,索引是一种供服务器在表中快速查找一个行的数据库结构,是建立在表的一列或者多列上的辅助对象,目的是加快访问表中的数据。索引的作用:1、快速存取数据;2、既可以改善数据库性能,又可以保证列值的唯一性等等。
本教程操作环境:Windows7系统、Oracle 11g版、Dell G3电脑。
什么是索引?
在oracle中,索引是一种供服务器在表中快速查找一个行的数据库结构。
- 索引是建立在表的一列或者多列上的辅助对象,目的是加快访问表中的数据。 
- oracle 存储索引的结构是B*数(平衡树),而索引是由根节点、分支点和叶子点组成,上级索引块包含下级索引块的索引数据,叶节点包含索引数据和确定行实际位置的rowid。 
在数据库中建立索引主要有以下作用:
(1)快速存取数据。
(2)减少I/O操作
(3)既可以改善数据库性能,又可以保证列值的唯一性。
(4)实现表与表之间的参照完整性
(5)在使用orderby、groupby子句进行数据检索时,利用索引可以减少排序和分组的时间。
什么时候用:
- 作为where后查询条件的字段适合建立索引。 
什么时候不用:
- 重复字段较多; 
- 不作为where后查询条件的字段; 
- 表中记录较少。 
怎么用索引:
创建索引:
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];
                                        --表示创建索引时不进行排序,默认不适用,如果数据已经是按照该索引顺序排列的可以使用例如,
创建商品表:
-- Create table
create table TB_GOODS
(
  goods_id    VARCHAR2(64) not null,
  goods_name  VARCHAR2(256) not null,
  goods_price VARCHAR2(64) not null,
  status      VARCHAR2(1) not null
);
    创建索引:
--这里unique可以省略,若省略则索引为非唯一索引
create index UI_tb_goods on tb_goods(goods_name);
    
--若使用unique则为唯一索引
create unique index un_tb_goods on tb_goods(goods_name);
    
--括号中添加两列则为组合索引
create unique index un2_tb_goods on tb_goods(goods_name,status);
    
--括号中添加三列,其顺序没有关系,效果是一样的
create unique index un3_tb_goods on tb_goods(goods_name,goods_price,status);
    唯一索引的另一个作用,控制该列不能有相同值!
查询索引:
select * from user_indexes where table_name='表名';
    
select * from user_ind_columns  where index_name='索引名';
    到此这篇关于“oracle中建立索引有什么用,什么时候使用索引”的文章就介绍到这了,感谢各位的阅读,更多相关oracle中建立索引有什么用,什么时候使用索引内容,欢迎关注网络资讯频道,小编将为大家输出更多高质量的实用文章!
声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!
若转载请注明出处: oracle中建立索引有什么用,什么时候使用索引
本文地址: https://pptw.com/jishu/649944.html
