在Oracle数据库中,索引是提升数据查询效率的核心结构,不同的查询条件会触发不同的索引访问方法,掌握这些访问方法的原理和适用场景,是进行SQL性能优化的基础。

常见索引访问方法分类
Oracle中索引访问方法主要分为以下几类,每种方法对应不同的查询场景,执行计划中会显示对应的操作名称:
- 索引唯一扫描(INDEX UNIQUE SCAN):针对唯一索引的等值查询,最多返回一条记录
- 索引范围扫描(INDEX RANGE SCAN):针对索引的范围查询或等值查询返回多条记录
- 索引全扫描(INDEX FULL SCAN):遍历整个索引的所有叶子节点
- 索引快速全扫描(INDEX FAST FULL SCAN):多块读方式扫描整个索引,不保证顺序
- 索引跳跃扫描(INDEX SKIP SCAN):针对复合索引前导列未出现在查询条件中的场景
各访问方法详解与示例
1. 索引唯一扫描
当查询条件是对唯一索引的列进行等值匹配时,Oracle会采用索引唯一扫描,这种方式效率最高,因为唯一索引的键值不重复,找到匹配项后即可停止扫描。
首先创建测试表和唯一索引:
-- 创建测试表
CREATE TABLE user_info (
user_id NUMBER PRIMARY KEY,
user_name VARCHAR2(50),
age NUMBER
);
-- 插入测试数据
INSERT INTO user_info VALUES (1, '张三', 25);
INSERT INTO user_info VALUES (2, '李四', 30);
INSERT INTO user_info VALUES (3, '王五', 28);
COMMIT;
-- user_id上的主键索引就是唯一索引,执行以下查询会触发索引唯一扫描
SELECT * FROM user_info WHERE user_id = 1;查看该语句的执行计划,会看到INDEX UNIQUE SCAN操作,对应的对象是主键索引。
2. 索引范围扫描
当查询条件是对索引列进行范围匹配(如BETWEEN、>、<),或者等值查询的索引不是唯一索引时,会触发索引范围扫描,扫描会沿着索引叶子节点的链表进行,直到不满足查询条件为止。
先创建普通索引:
-- 在age列创建普通索引 CREATE INDEX idx_user_age ON user_info(age); -- 范围查询,触发索引范围扫描 SELECT * FROM user_info WHERE age BETWEEN 25 AND 30; -- 等值查询普通索引,返回多条记录也会触发索引范围扫描 SELECT * FROM user_info WHERE age = 28;
3. 索引全扫描
当查询需要获取索引列的所有值,或者查询条件中索引列上有ORDER BY且顺序和索引一致,同时不需要回表获取其他列时,会触发索引全扫描。索引全扫描会按顺序遍历整个索引的叶子节点,单块读方式读取。
-- 查询所有用户的age,只需要索引列的值,触发索引全扫描 SELECT age FROM user_info ORDER BY age;
4. 索引快速全扫描
当查询只需要索引列的值,不需要保证顺序,且会扫描整个索引时,Oracle可能选择索引快速全扫描,这种方式采用多块读,速度比索引全扫描更快,但返回的结果顺序不保证和索引顺序一致。
-- 统计所有用户的年龄总和,只需要索引列的值,可能触发索引快速全扫描 SELECT SUM(age) FROM user_info;
5. 索引跳跃扫描
当查询条件中使用了复合索引的非前导列,而前导列没有出现在查询条件中时,Oracle可能会采用索引跳跃扫描,这种方式会逻辑上将复合索引拆分为多个子索引进行扫描。
先创建复合索引:
-- 创建复合索引,前导列为user_name,第二列为age CREATE INDEX idx_user_name_age ON user_info(user_name, age); -- 查询条件只使用age列,未使用user_name,可能触发索引跳跃扫描 SELECT * FROM user_info WHERE age = 30;
如何判断当前查询使用的索引访问方法
可以通过EXPLAIN PLAN命令或者查询动态性能视图来获取SQL的执行计划,查看索引访问相关的操作:
-- 生成执行计划 EXPLAIN PLAN FOR SELECT * FROM user_info WHERE user_id = 1; -- 查看执行计划 SELECT * FROM TABLE(DBMS_XPLAN.DISPLAY);
执行计划的Operation列会显示对应的索引访问方法,Object Name列会显示使用的索引名称,结合这两个信息就能明确当前查询的索引访问方式。
访问方法选择的影响因素
Oracle优化器会根据统计信息、查询条件、返回数据量等因素选择最合适的索引访问方法,实际优化时需要注意:
- 及时收集表和索引的统计信息,避免优化器选择错误的访问方式
- 复合索引的创建顺序要符合查询条件的常用组合,减少索引跳跃扫描的使用
- 如果查询只需要索引列的值,尽量只查询索引列,避免回表操作提升效率
- 对于小表的全表扫描可能比索引访问效率更高,不需要强制使用索引