Oracle索引的原理及使⽤
⼀、说明
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]INDEXindex_name--unique表⽰唯⼀索引
ONtable_name([column1[ASC|DESC],column2--bitmap,创建位图索引
[ASC|DESC],…]|[express])[TABLESPACEtablespace_name]
[PCTFREEn1]--指定索引在数据块中空闲空间
[STORAGE(INITIALn2)]
[NOLOGGING]--表⽰创建和重建索引时允许对表做DML操作,默认情况下不应该使⽤
[NOLINE]
[NOSORT];--表⽰创建索引时不进⾏排序,默认不适⽤,如果数据已经是按照该索引顺序排列的可以使⽤
2.修改索引
1)重命名索引
alterindexindex_snorenametobitmap_index;
2)合并索引(表使⽤⼀段时间后在索引中会产⽣碎⽚,此时索引效率会降低,可以选择重
建索引或者合并索引,合并索引⽅式更好些,⽆需额外存储空间,代价较低)
alterindexindex_snocoalesce;
3)重建索引
⽅式⼀:删除原来的索引,重新建⽴索引
⽅式⼆:
alterindexindex_snorebuild;
3.删除索引
dropindexindex_sno;
4.查看索引
lectindex_name,index-type,tablespace_name,uniquenessfromall_indexeswheretable_name='tablename';--eg:
createindexindex_snoonstudent('name');lect*fromall_indexeswheretable_name='student';
五、索引分类
1.B树索引(默认索引,保存讲过排序过的索引列和对应的rowid值)
1)说明:
中最常⽤的索引;B树索引就是⼀颗⼆叉树;叶⼦节点(双向链表)包含索引列和指向表中每个匹配⾏的ROWID值
2.所有叶⼦节点具有相同的深度,因⽽不管查询条件怎样,查询速度基本相同
3.能够适应精确查询、模糊查询和⽐较查询
2)分类:
UNIQUE,NON-UNIQUE(默认),REVERSEKEY(数据列中的数据是反向存储的)
3)创建例⼦
craeteindexindex_snoonstudent('sno');
4)适合使⽤场景:
列基数(列不重复值的个数)⼤时适合使⽤B数索引
2.位图索引
1)说明:
1.创建位图索引时,oracle会扫描整张表,并为索引列的每个取值建⽴⼀个位图(位图中,对表中每⼀⾏使⽤⼀位(bit,0或者1)来标识该⾏是
否包含该位图的索引列的取值,如果为1,表⽰对应的rowid所在的记录包含该位图索引列值),最后通过位图索引中的映射函数完成位到⾏的
ROWID的转换
2)创建例⼦
createbitmapindexindex_snoonstudent(sno);
3)适合场景:
对于基数⼩的列适合简历位图索引(例如性别等)
3.单列索引和复合索引(基于多个列创建)
1.注意:
即如果索引建⽴在多个列上,只有它的第⼀个列被where⼦句引⽤时,优化器才会使⽤该索引,即⾄少要包含组合索引的第⼀列
4.函数索引
1)说明:
1.当经常要访问⼀些函数或者表达式时,可以将其存储在索引中,这样下次访问时,该值已经计算出来了,可以加快查询速度
2.函数索引既可以使⽤B数索引,也可以使⽤位图索引;当函数结果不确定时采⽤B树索引,结果是固定的某⼏个值时使⽤位图索引
3.函数索引中可以⽔泥⽤len、trim、substr、upper(每⾏返回独⽴结果),不能使⽤如sum、max、min、avg等
2)例⼦:
createindexfbionstudent(upper(name));lect*fromstudentwhereupper(name)='WISH';
索引建⽴原则总结
1.如果有两个或者以上的索引,其中有⼀个唯⼀性索引,⽽其他是⾮唯⼀,这种情况下oracle将使⽤唯⼀性索引⽽完全忽略⾮唯⼀性索引
2.⾄少要包含组合索引的第⼀列(即如果索引建⽴在多个列上,只有它的第⼀个列被where⼦句引⽤时,优化器才会使⽤该索引)
3.⼩表不要简历索引
4.对于基数⼤的列适合建⽴B树索引,对于基数⼩的列适合简历位图索引
5.列中有很多空值,但经常查询该列上⾮空记录时应该建⽴索引
6.经常进⾏连接查询的列应该创建索引
7.使⽤createindex时要将最常查询的列放在最前⾯
(可变长字符串数据,最长2G)和LONGRAW(可变长⼆进制数据,最长2G)列不能创建索引
9.限制表中索引的数量(创建索引耗费时间,并且随数据量的增⼤⽽增⼤;索引会占⽤物理空间;当对表中的数据进⾏增加、删除和修改的时候,
索引也要动态的维护,降低了数据的维护速度)
注意事项
1.通配符在搜索词⾸出现时,oracle不能使⽤索引,eg:
--我们在name上创建索引;
createindexindex_nameonstudent('name');--下⾯的⽅式oracle不适⽤name索引
lect*fromstudentwherenamelike'%wish%';--如果通配符出现在字符串的其他位置时,优化器能够利⽤索引;如下:
lect*fromstudentwherenamelike'wish%';
2.不要在索引列上使⽤not,可以采⽤其他⽅式代替如下:(oracle碰到not会停⽌使⽤索引,⽽采⽤全表扫描)
lect*fromstudentwherenot(score=100);lect*fromstudentwherescore<>100;--替换为
lect*fromstudentwherescore>100orscore<100
3.索引上使⽤空值⽐较将停⽌使⽤索引,eg:
lect*fromstudentwherescoreisnotnull;
本文发布于:2023-02-02 05:38:39,感谢您对本站的认可!
本文链接:http://www.wtabcd.cn/fanwen/fan/88/176682.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |