在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
一、简介说明:
二、索引原理
三、索引使用(创建、修改、删除、查看)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'; 四、索引分类1. B树索引(默认索引,保存讲过排序过的索引列和对应的rowid值) 1)说明:
2)分类:
3)创建例子 craete index index_sno on student('sno'); 4)适合使用场景: 列基数(列不重复值的个数)大时适合使用B数索引 2. 位图索引1)说明: 1.创建位图索引时,oracle会扫描整张表,并为索引列的每个取值建立一个位图(位图中,对表中每一行使用一位(bit,0或者1)来标识该行是否包含该位图的索引列的取值,如果为1,表示对应的rowid所在的记录包含该位图索引列值),最后通过位图索引中的映射函数完成位到行的ROWID的转换 2)创建例子 create bitmap index index_sno on student(sno); 3) 适合场景: 对于基数小的列适合简历位图索引(例如性别等) 3.单列索引和复合索引(基于多个列创建)1) 注意: 即如果索引建立在多个列上,只有它的第一个列被where子句引用时,优化器才会使用该索引,即至少要包含组合索引的第一列 4. 函数索引1)说明: 1. 当经常要访问一些函数或者表达式时,可以将其存储在索引中,这样下次访问时,该值已经计算出来了,可以加快查询速度 2. 函数索引既可以使用B数索引,也可以使用位图索引;当函数结果不确定时采用B树索引,结果是固定的某几个值时使用位图索引 3. 函数索引中可以水泥用 2)例子: create index fbi on student (upper(name)); select * from student where upper(name) ='WISH'; 五、索引建立原则总结
注意事项: 1. 通配符在搜索词首出现时,oracle不能使用索引,eg: --我们在name上创建索引; create index index_name on student('name'); --下面的方式oracle不适用name索引 select * from student where name like '%wish%'; --如果通配符出现在字符串的其他位置时,优化器能够利用索引;如下: select * from student where name like 'wish%'; 2. 不要在索引列上使用not,可以采用其他方式代替如下:(oracle碰到not会停止使用索引,而采用全表扫描) select * from student where not (score=100); select * from student where score <> 100; --替换为 select * from student where score>100 or score <100 3. 索引上使用空值比较将停止使用索引, eg: select * from student where score is not null; 到此这篇关于 |
请发表评论