Oracle学习笔记——什么是索引,为什么用索引,什么时候用,什么时候不用,怎么用索引--2018-07-23

什么是索引?

索引就是将表中某几个字段提取出来,开辟新的存储空间并进行排序,并且把所有值和rowid存储其中,并用一个指针指向表中原来对应行的记录。

 

为什么用索引:

  1. 快速查找数据库表中某条数据;
  2. 减少I/O操作。

什么时候用:

  1. 作为where后查询条件的字段适合建立索引。

什么时候不用:

  1. 重复字段较多;
  2. 不作为where后查询条件的字段;
  3. 表中记录较少。

怎么用索引:

创建索引:

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学习笔记)