Oracle索引的原理及使用
一、前引
- 索引在数据库中扮演着非常重要的角色,是数据库对象之一,用于加快数据的检索,类似于书籍的目录。在数据库中索引可以减少数据库程序查询结果时需要读取的数据量,类似于在书籍中我们利用索引可以不用翻阅整本书即可找到想要的信息。
- 索引是建立在表上的可选对象,索引的关键在于通过一组排序后的索引键来取代默认的全表扫描检索方式,从而提高检索效率。
- 索引在逻辑上和物理上都与相关的表和数据无关,当创建或者删除一个索引时,不会影响基本的表。
- 索引一旦建立,在表上进行DML操作时(例如在执行插入、修改或者删除相关操作时),oracle会自动管理索引,索引删除,不会对表产生影响。
- 索引对用户是透明的,无论表上是否有索引,sql语句的用法不变。
- oracle创建主键时会自动在该列上创建索引。
二、索引原理
- 若没有索引,搜索某个记录时(例如查找name='张三')需要搜索所有的记录,因为不能保证只有一个张三,必须全部搜索一遍。
- 若在name上建立索引,oracle会对全表进行一次搜索,将每条记录的name值哪找升序排列(建立索引时做的),然后构建索引条目(name和rowid),存储到索引段中,查询name为张三时即可直接查找对应地方。
- 创建了索引并不一定就会使用,oracle自动统计表的信息后,决定是否使用索引,表中数据很少时使用全表扫描速度已经很快,没有必要使用索引。
- 占用存储空间:索引实际上也是一张表,记录了主键与索引字段,一般以索引文件的形式存储在磁盘上。
- 降低更新表的速度:表的数据发生了变化,对应的索引也需要一起变更,从而减低的更新速度。否则索引指向的物理数据可能不对,这也是索引失效的原因之一。
- 特大型的表,建立和使用索引的代价随着增长,可以使用分区技术来解决。
三、使用
- 语法
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]; --表示创建索引时不进行排序,默认不适用,如果数据已经是按照该索引顺序排列的可以使用
例子:
--给列 localid 添加索引(索引名称一般就是表名加个index_列名)
create Index index_localid_STATATIC_YEAR on STATATIC_YEAR(localid);
- 修改索引
alter index index_localid_STATATIC_YEAR rename to bitmap_index;
- 合并索引( 表使用一段时间后在索引中会产生碎片,此时索引效率会降低,可以选择重建索引或者合并索引,合并索引方式更好些,无需额外存储空间,代价较低)
alter index index_localid_STATATIC_YEAR coalesce;
- 重建索引
方式一:删除原来的索引,重新建立索引
方式二:
alter index index_localid_STATATIC_YEAR rebuild;
- 删除索引
drop index index_localid_STATATIC_YEAR;
- 查看索引
---查询索引
select * from user_indexes where table_name='PEOPLE' select index_name,index-type, tablespace_name, uniqueness from all_indexes where table_name ='tablename';
-- 创建例子
create index index_sno on student('name');
select * from all_indexes where table_name='student';
四、索引分类
B树索引(默认索引)
- 创建
craete index index_sno on student('sno');
说明
- oracle中最常用的索引;
- B树索引就是一颗二叉树;
- 叶子节点(双向链表)包含索引列和指向表中每个匹配行的ROWID值;
- 所有叶子节点具有相同的深度,因而不管查询条件怎样,查询速度基本相同;
- 能够适应精确查询、模糊查询和比较查询;
使用场景
列基数(列不重复值的个数)大时适合使用B数索引
位图索引
- 创建
create bitmap index index_sno on student(sno);
说明
- 创建位图索引时,oracle会扫描整张表,并为索引列的每个取值建立一个位图(位图中,对表中每一行使用一位(bit,0或者1)来标识该行是否包含该位图的索引列的取值,如果为1,表示对应的rowid所在的记录包含该位图索引列值),最后通过位图索引中的映射函数完成位到行的ROWID的转换。
使用场景
对于基数小的列适合简历位图索引(例如性别等)
复合索引(基于多个列创建)
- 创建
craete index index_sno on student('sno','sex');
- 说明
- 创建符合索引时,注意多个列的前后顺序,会影响查询的效率。
- 选择经常在WHERE中使用,并且是由AND进行连接的列做符合索引列。
- 选择WHERE中使用频率相对较高的列排在前面,或者根据需要为其他列创建单独的索引。
- 只有复合索引中的第一列被WHERE子句使用时,Oracle才会使用该复合索引。
函数索引
- 创建
create index fbi on student (upper(name));
select * from student where upper(name) ='WISH';
- 说明
- 当经常要访问一些函数或者表达式时,可以将其存储在索引中,这样下次访问时,该值已经计算出来了,可以加快查询速度。
- 函数索引中可以使用len、trim、substr、upper(每行返回独立结果),不能使用如sum、max、min、avg等。
-- 常用函数
-- lower:大写字符转化成百小写的函数select lower(表中字段) from 表名 --将表里的字问段信息中含有字母答的全部转回成小写
-- upper:小写字答符转化成大写的函数select upper(表中字段) from 表名 --将 user表里的字段信息中含有字母的全部转成大写
-- substr:切割字符串
create index t_object_type_idn_fun on t(substr(object_type,1,3));
select * from t where substr(t.object_type,1,3)='XXX';
五、索引建立原则
- 如果有两个或者以上的索引,其中有一个唯一性索引,而其他是非唯一,这种情况下oracle将使用唯一性索引而完全忽略非唯一性索引
- 至少要包含组合索引的第一列(即如果索引建立在多个列上,只有它的第一个列被where子句引用时,优化器才会使用该索引)
- 小表不要简历索引
- 对于基数大的列适合建立B树索引,对于基数小的列适合简历位图索引
- 列中有很多空值,但经常查询该列上非空记录时应该建立索引
- 经常进行连接查询的列应该创建索引
- 使用create index时要将最常查询的列放在最前面
- LONG(可变长字符串数据,最长2G)和LONG RAW(可变长二进制数据,最长2G)列不能创建索引。
- 限制表中索引的数量(创建索引耗费时间,并且随数据量的增大而增大;索引会占用物理空间;当对表中的数据进行增加、删除和修改的时候,索引也要动态的维护,降低了数据的维护速度)。
六、举个栗子
- 通配符在搜索词首出现时,oracle不能使用索引
--在name上创建索引;
create index index_name on student('name');
--下面的方式oracle不适用name索引
select * from student where name like '%wish%';
--如果通配符出现在字符串的其他位置时,优化器能够利用索引
select * from student where name like 'wish%';
- 不要在索引列上使用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
- 索引上使用空值比较将停止使用索引
select * from student where score is not null;
Oracle索引的原理及使用相关推荐
- Oracle 反向键索引的原理和用途(减少索引热点块)
Oracle 反向键索引的原理和用途(减少索引热点块) 我们知道Oracle会自动为表的主键列建立索引,这个默认的索引是普通的B-Tree索引.对于主键值是按顺序(递增或递减)加入的情况,默认的B-T ...
- Oracle索引详解(索引的原理,创建索引,删除索引,修改索引等)
Oracle索引详解 一.索引概述 Oracle作为关系型数据库,用户查找数据与行的物理位置无关,表中的每一行均用一个ROWID来标识,当Oracle数据库中存储海量的记录时,就意味着有大量的ROWI ...
- 索引名 oracle,ORACLE 索引名称矫情
oracle 索引英文名称很多,翻译过来的话也很多中文名称,不过总得来说词不达意.也就是说讲中文的时候,对方无法理解你说的是啥意思,啥情况,啥原理. 比如前缀,非前缀.本地和全局,普通和分区.B树和位 ...
- oracle索引对模糊查询,Oracle索引
一.Oracle索引原理 通俗易懂得讲,索引就是给每条记录建立了一个目录(索引), 每个建立的索引都是按照这个索引的字段去排序(实际未必是排序)存放, 然后按照索引字段去查询的时候,就先去查询索引,此 ...
- Oracle特殊恢复原理与实战(DSI系列)
1.深入浅出Oracle(DSI系列Ⅰ) 2.Oracle特殊恢复原理与实战(DSI系列Ⅱ) 3.Oracle SQL Tuning(DSI系列Ⅲ)即将开设 4.Oracle DB Performan ...
- 万字详解Oracle架构、原理、进程,学会世间再无复杂架构
学习是一个循序渐进的过程,从面到点.从宏观到微观,逐步渗透,各个击破,对于Oracle, 怎么样从宏观上来理解呢?先来看一个图,这个图取自于教材,这个图对于从整体上理解ORACLE 的体系结构组件,非 ...
- 详解Oracle架构、原理、进程,学会世间再无复杂架构
详解Oracle架构.原理.进程,学会世间再无复杂架构 学习是一个循序渐进的过程,从面到点.从宏观到微观,逐步渗透,各个击破,对于Oracle, 怎么样从宏观上来理解呢?先来看一个图,这个图取自于教材 ...
- Oracle索引和事务
Oracle索引和事务 1. 什么是索引?有什么用? 1.索引是数据库对象之一,用于加快数据的检索,类似于书籍的目录.在数据库中索引可以减少数据库程序查询结果时需要读取的数据量,类似于在书籍中我们利用 ...
- oracle 索引的定义及使用
一.索引的概念: 索引是建立在表上的可选数据库对象,是一组排序后的的索引键.主要用于加快数据的检索,类似于书籍的目录,快速定位到目标数据.索引在物理上和逻辑上都是独立的,创建或删除索引对基表不会有影响 ...
- 数据库索引的原理到底是什么?
引言 中小企业MIS系统的管理基本上由两大部份组成,一是前台的可视化操作,二是后台的数据库管理.网管对前台的管理和维护工作包括保障网络链路通畅.处理MIS终端的突发事件以及对操作员的管理.培训等,这是 ...
最新文章
- 小米路由器添加扩展工具_小米正式发布miVela软件平台,与各方共同合作推进物联网发展...
- boost::system::linux_error相关的测试程序
- 服务器不重启磁盘修复,重启后数据盘不见了?别担心,只是磁盘脱机
- 文通表格识别系统是表格数据录入的好帮手
- 噪声的频谱分析的重要意义_噪声测量:噪声源识别与定位的方法简析
- python * args和** kwargs的用法
- 判断Windows服务是否启动
- 区块链xuperchain ubuntu多机多节点 single共识 部署教程
- zlog日志库的简单封装,以及给debug级别添加颜色显示
- 高一计算机课程教案,高一信息技术教案第一章
- 搭建机器人电控系统——通信协议——IIC通信原理及其实例(库函数+模拟IO口)
- TCP-IP详解:SACK选项(Selective Acknowledgment)
- 图像原点矩、二阶中心矩物理意义推导
- JavaFX+Kotlin游戏从入门到放弃:拯救蛇蛇大作战又名454行实现几何数独游戏
- MySql中增加一列
- 欧姆龙服务器数码管不显示问题,数显仪表常见故障的原理分析以及解决方案
- Anaconda环境的创建、激活、删除和管理
- 看影片《明日边缘》有感
- C语言:一元二次方程(输入系数a,b,c输出一元二次方程解)
- 游戏开发杂记(一) 万事开头难