gbase8s数据库常见的索引扫描方式

1 顺序扫描(Sequential scan):数据库服务器按照物理顺序读取表中的所有记录。

常发生在表上无索引或者数据量很少或者一些无法使用索引的sql语句中

2 索引扫描(Index scan):数据库服务器读取索引页,并通过相应的 ROWID 来读取相关的记录。

3 键值扫描(Key-only index scan):如果读取的相关数据包含在索引节点中,数据库服务器就只需读取索引,不需要再去读取相应的数据页。

4 键优先扫描(Key-first index scan):键优先扫描是一种索引扫描,它首先使用索引键过滤器来减少查询读取的数据量。

5 自动索引扫描(Auto-index scan):自动索引扫描特性允许数据库服务器在一个或多个字段上自动创建临时索引,数据库服务器通过这个临时索引读取相应的数据。这个临时索引只在查询过程中生效。

6 多路径扫描 (skip-scan):当数据表上有多个查询字段时,优化器有可能会选择多路径扫描,即同时扫描多字段上的索引 在对所有扫描命中的rowID 取交集

7 索引反转 :在创建索引时默认为升序排序,当sql语句中存在 降序排序时会反转索引

8 rowid扫描: 直接读取位于指定物理位置(由 ROWID 指定)的数据行

9 跳过-重复-索引扫描(skip-duplicate-index):此种扫描模式大多发生在索引嵌套循环的半连接中,例如使用 exists子查询时,内表在扫描到结果时则停止继续扫描

例如

create table ti(c1 int,c2 varchar(50));

insert into ti select level,sys_guid() from dual connect by level < 1000;

create index index_ti_c1 on ti(c1);

select c1 from ti where 1=1

此时发生顺序扫描

执行 select * from ti where c1 = 125时发生索引扫描

执行 select c1 from ti where c1 = 125时发生键值扫描

create table tl(c1 int,c2 int,c3 varchar(50));

insert into tl select level,level +100,sys_guid() from dual connect by level < 100000;

create index index_tl_c12 on tl(c1,c2);

select /*+INDEX(tl index_tl_c12) */ * from tl where (c1 > 0) and (c2 =1000 or c2=55667);

hint强制使用键优先扫描

自动索引扫描更常见的是发生在exists 子句

select * from ti where exists(select 1 from tk where ti.c2=tk.c2);

多路径扫描 常发生在多个查询条件时

此处使用hint 强制控制多路径扫描

select /*+ MULTI_INDEX (ti index_ti_c1,index_ti_c2) */ * from ti where c1 > 150000 and c2 in ('58F6ADC849EB4A489BBBE679AF8CC3F1','3BDD7CE3C5504DA4A399A75B4ACFC026','B927DF1AF6E64EF4BA7310CF4E182236','','');

索引反转:select c1 from ti order by c1 desc;

select * from ti where rowid=444

相关推荐
kura_tsuki2 小时前
[Oracle数据库] Oracle 常用函数
数据库·oracle
YA3333 小时前
java基础(十)sql的mvcc
数据库
weixin_307779137 小时前
VS Code配置MinGW64编译SQLite3库
开发语言·数据库·c++·vscode·算法
SelectDB7 小时前
Apache Doris 4.0 AI 能力揭秘(一):AI 函数之 LLM 函数介绍
数据库·人工智能·数据分析
我是哈哈hh7 小时前
【MySQL】在UBuntu环境安装以及免密码登录入门
linux·数据库·mysql·ubuntu
喪彪8 小时前
MySQL新手教学
数据库·mysql·adb
丘大梨10 小时前
QT 基础聊天应用项目文档
运维·数据库·系统架构
HMBBLOVEPDX11 小时前
MySQL的多版本并发控制(MVCC):
数据库·mysql·mvcc
.用户昵称已存在.11 小时前
MongoDB 从入门到精通:安装配置与基础操作指令详解
数据库·mongodb