索引的概念

  • 索引的概念

    1.索引是一种可选的与表相关的数据库对象,用于提高数据的查询效率。

    2.索引是一种有序的数据结构。

    3.如果一个表没有创建索引,则对该表进行查询时需要进行全表扫描;如果创建了索引,则在有条件查询时,系统先对索引进行查询,利用索引可以迅速查询到符合条件的数据。

    4.利用索引之所以能够提高查询效率,是因为在索引结构中保存了索引值及其相应记录的物理地址 ,即ROWID,并且按照索引值进行排序。当查询数据时,系统根据查询条件中的索引信息,利用特定的排序算法在索引结构中很快查询到相应的索引值及其对应 ROWID,根据ROWID可以在数据表中很快查询到符合条件的记录。如图所示:

  • ROWID 的概念与作用

    1.在Oracle数据库中,ROWIN 是一个伪列,系统自动产生,能唯一标识每一条数据库行记录的 物理地址 ,通过ROWIN能快速定位到一条行记录。

    2.ROWID由18位16进制数构成。其中前1-6位为数据对象编号,7-9位为数据文件编号,10-15数据块编号,最后 3位为块中行 编号。

    3.因为使用ROWID可以快速定位记录,所以使用ROWIN检索及操作数据,效率最快。

  • 索引分类

    1.根据索引值是否唯一,可分为唯一性索引 和 非唯一性索引

    2.根据索引的组织结构不同,可分为平衡数索引 和 位图索引

    3.根据索引基于的列数不同,可以分为单列索引 和 复合索引

  • 创建索引语法

    1.创建索引使用 create index 索引名称 on 表名

    2.创建非唯一性索引:create index 索引名 on 表名

    3.创建唯一性索引: create unique index 索引名 on 表名

    4.创建复合索引: create index 索引名 on user( username, userage)

  • 创建索引原则

    由于索引作为一个独立的数据库对象存在,占用存储空间,并且需要系统进行维护,因此是否创建索引和创建什么样的索引需要遵循一定的原则。下列情况下 ,适合创建索引:

    1.表中数据量很大

    2.要查询的结果占表中的数据的 2% - %4

    3.经常用来做where条件中的列或者多表连接的列

    4.查询列的数据范围分布很广

    5.查询列中包含大量的Null值,因为空值不包含在索引中

    下列情况不适合创建索引

    1.数据量很小的表

    2.在查询中不常用来作为查询条件的列

    3.频繁更新的表

    4.查询条件中有单行函数时,用不上索引

    5.索引列作为表达式的一部分被使用 时,比如查询的条件是 salary * 12,此时在 salary 列上创建索引是没有效果的。

  • 删除索引

    下面几种情况可以考虑删除索引:

    1.索引不在使用

    2.通过一段事件监视,发现几乎没有查询或只有少数查询会使用该索引。

    3.由于移动了表数据而导致索引失效。

    删除索引后,索引中的数据及定义被删除,索引所占的数据空间被释放,但表中的数据仍然存在 。

    1.如果索引是通过create index 语句创建的,可以使用drop index 语句删除索引,语法为: drop index 索引名

    2.如果索引是定义约束时自动建立的,则禁用约束或删除约束时会自动删除对应的索引。

    3.此外,删除表时会自动删除与其相关的所有索引。

  • 查询索引信息

    1.可以通过查询 数据字典视图 或 动态性能视图 获取索引信息。

    2.数据字典视图 USER_INDEXES 包含索引的基本描述信息和统计信息,包括索引的所有者 、索引名称、索引的类型 、对应表的名称等等。

    3.数据字典视图 USER_IND_COLUMNS 包含索引列的描述信息,包括索引的名称、表的名称和索引列的名称等信息。

    例:select* from USER_INDEXES

相关推荐
倔强的石头_12 小时前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou642 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
李广坤3 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
爱可生开源社区4 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1774 天前
《从零搭建NestJS项目》
数据库·typescript
加号34 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏4 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐4 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再4 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip
tryCbest4 天前
数据库SQL学习
数据库·sql