Oracle索引

索引是关系数据库中对某一列或多个列的值进行预排序的数据结构。通过使用索引,可以让数据库系统不必扫描整个表,而是直接定位到符合条件的记录,这样就可以加快了查询速率,因此,他最大的作用就是用来优化数据库查询的效率,提升数据库的查询性能。

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

索引在逻辑上和物理上都与相关的表和数据无关,当创建或者删除一个索引时,表通常都不会受到影响。当索引一旦建立起来,在表上进行一系列的DML操作时(例如在执行插入、修改或者删除相关操作时),oracle会自动管理索引,索引删除,不会对表产生影响。

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

oracle创建主键时会自动在该列上创建索引。使用主键索引的效率是最高的,因为主键会保证绝对唯一。

对于上表来说,如果要经常要用salary来进行查询的话,那么,就可以根据salary来创建一个索引:

使用ADD INDEX idx_salary (salary)就创建了一个名称为idx_salary,使用列salary的索引。索引名称是任意的,索引如果有多个的话,就可以在括号里依次写上,例如:

索引的效率取决于索引列的值是否散列,即该列的值如果越互不相同,那么索引效率越高。反过来,如果记录的列存在大量相同的值,例如job_id,重复的值比较多,因此,对该列创建索引的意义就不是很大。

创建索引的基本语法:

[UNIQUE] 指定索引列上的值必须是唯一的,称为唯一索引; [BITMAP] 表示位图索引; index_name:指定索引名; tabl_name:指定要为哪个表创建索引; column_name:指定要对哪个列创建索引。我们也可以对多列创建索引,这种索引称为组合索引。也可以是函数表达式,这种就是函数索引。[EXPRESS]表示函数索引;[TABLESPACE]表示索引存储的表空间;[PCTFREE n1]指定索引在数据块中空闲空间;[ NOLOGGING]表示创建和重建索引时允许对表做DML操作,默认情况下不应该使用; [STORAGE]存储块的空间( initial 64K --初始64k next 1M) ;[NOSORT]表示创建索引时不进行排序,默认不适用,如果数据已经是按照该索引顺序排列的可以使用;

重命名索引

ALTER INDEX index_one RENAME TO index_two;

合并索引、重新构造索引:我们索引建好后,经过很长一段时间的使用,索引表中存储的空间会产生一些碎片,导致索引的查询效率会有所下降,这个时候可以合并索引,原理是按照索引规则重新分类存储一下,或者也可以选择删除索引重新构造索引, 合并索引方式更好些,无需额外存储空间,代价较低.

ALTER INDEX index_name COALESCE;--合并索引ALTER INDEX index_name REBUILD;--重新构造

删除索引

DROP INDEX index_name;

直接进行删除就行了

查看索引

SELECT index_name,index-type, tablespace_name, uniqueness from all_indexes where table_name ='tablename';

index_name索引名字; index_type索引类型; tablespace_name表空间; UNIQUENESS是否唯一索引 ;

索引分类

B树索引(默认索引,保存排序过的索引列和对应的ROWID值)

oracle中最常用的索引;B树索引就是一颗二叉树;叶子节点(双向链表)包含索引列和指向表中每个匹配行的ROWID值;

所有叶子节点具有相同的深度,因而不管查询条件怎样,查询速度基本相同;

能够适应精确查询、模糊查询和比较查询;

UNIQUE,NON-UNIQUE(默认),REVERSE KEY(数据列中的数据是反向存储的);

列基数(列不重复值的个数)大时适合使用B数索引。

 

位图索引

创建位图索引时,oracle会扫描整张表,并为索引列的每个取值建立一个位图(位图中,对表中每一行使用一位(bit,0或者1)来标识该行是否包含该位图的索引列的取值,如果为1,表示对应的ROWID所在的记录包含该位图索引列值),最后通过位图索 引中的映射函数完成位到行的ROWID的转换;

对于基数小的列适合简历位图索引(例如证件类型等)

单列索引和复合索引(基于多个列创建)

即如果索引建立在多个列上,只有它的第一个列被where子句引用时,优化器才会使用该索引,即至少要包含组合索引的第一列

函数索引

当经常要访问一些函数或者表达式时,可以将其存储在索引中,这样下次访问时,该值已经计算出来了,可以加快查询速度

函数索引既可以使用B数索引,也可以使用位图索引;当函数结果不确定时采用B树索引,结果是固定的某几个值时就可以使用位图索引

函数索引中可以使用LEN、TEIM、SUBSTR、UPPER函数,不能使用如SUM、MAX、MIN、AVG等

小结

当我们在数据库中查询时,如果有相应的索引可用,数据库系统就会自动使用索引来提高查询效率,如果没有索引,查询也能够正常执行,只是速度会变慢。所以,索引可以在使用数据库的过程中逐步优化。

Oracle数据库的索引不管是对于用户还是对于应用程序来说它都是透明的,可用的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值