我的编程空间,编程开发者的网络收藏夹
学习永远不晚

oracle中访问索引的方法有哪些

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

oracle中访问索引的方法有哪些

这篇文章主要介绍“oracle中访问索引的方法有哪些”,在日常操作中,相信很多人在oracle中访问索引的方法有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”oracle中访问索引的方法有哪些”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

本文总结了访问索引的几种方法。

1、索引唯一扫描(INDEX UNIQUE SCAN)
(1)结果至多只返回一条记录

示例:
SQL> create table test.t as select * from dba_objects;
Table created

SQL> create unique index t_ius on t(object_id);
Index created.

SQL> select * from t where object_id=99338;
Execution Plan
----------------------------------------------------------
Plan hash value: 3945981348
-------------------------------------------------------------------------------------
| Id  | Operation                   | Name  | Rows  | Bytes | Cost (%CPU)| Time     |
-------------------------------------------------------------------------------------
|   0 | SELECT STATEMENT            |       |     1 |   207 |     2   (0)| 00:00:01 |
|   1 |  TABLE ACCESS BY INDEX ROWID| T     |     1 |   207 |     2   (0)| 00:00:01 |
|*  2 |   INDEX UNIQUE SCAN         | T_IUS |     1 |       |     1   (0)| 00:00:01 |
-------------------------------------------------------------------------------------

2、索引范围扫描(INDEX RANGE SCAN)
(1)索引范围扫描的结果可能会返回多条记录

示例:
SQL> create index t_irs on t(object_id);
Index created.

SQL> select * from t where object_id=99338;

Execution Plan
----------------------------------------------------------
Plan hash value: 735526888

-------------------------------------------------------------------------------------
| Id  | Operation                   | Name  | Rows  | Bytes | Cost (%CPU)| Time     |
-------------------------------------------------------------------------------------
|   0 | SELECT STATEMENT            |       |     1 |   207 |     2   (0)| 00:00:01 |
|   1 |  TABLE ACCESS BY INDEX ROWID| T     |     1 |   207 |     2   (0)| 00:00:01 |
|*  2 |   INDEX RANGE SCAN          | T_IRS |     1 |       |     1   (0)| 00:00:01 |
-------------------------------------------------------------------------------------

3、索引全扫描(INDEX FULL SCAN)
(1)扫描目标索引所有叶子块的所有索引行。
(2)索引全扫描的执行结果是有序的,避免了真正排序操作。
(3)通常情况下索引全扫面使用的是单块读。
(4)索引全扫面的前提条件是目标索引键值列的属性是not null.

示例:
SQL>  select object_id from t where object_id is not null order by object_id;
72920 rows selected.

Execution Plan
----------------------------------------------------------
Plan hash value: 3775890202

--------------------------------------------------------------------------
| Id  | Operation        | Name  | Rows  | Bytes | Cost (%CPU)| Time     |
--------------------------------------------------------------------------
|   0 | SELECT STATEMENT |       | 92167 |  1170K|   176   (0)| 00:00:03 |
|*  1 |  INDEX FULL SCAN | T_IRS | 92167 |  1170K|   176   (0)| 00:00:03 |
--------------------------------------------------------------------------

4、索引快速全扫面(NDEX FAST FULL SCAN)
(1)和索引全扫面一样,扫描目标索引所有叶子块的所有索引行。
(2)索引快速全扫描只适用于CBO。
(3)索引快速全扫面可以多块读,也可以并行执行。
(4)索引快速全扫描的执行结果不一定是有序的。

示例:
SQL>  select object_id from t where object_id is not null;
72920 rows selected.

Execution Plan
----------------------------------------------------------
Plan hash value: 723523614

------------------------------------------------------------------------------
| Id  | Operation            | Name  | Rows  | Bytes | Cost (%CPU)| Time     |
------------------------------------------------------------------------------
|   0 | SELECT STATEMENT     |       | 92167 |  1170K|    49   (0)| 00:00:01 |
|*  1 |  INDEX FAST FULL SCAN| T_IRS | 92167 |  1170K|    49   (0)| 00:00:01 |
———————————————————————————————————————d

5、索引跳跃式扫描(INDEX SKIP SCAN)
(1)适用于复合B树索引
(2) where条件中没有对目标索引的前导列指定查询条件同时又对该索引的非前导列指定了查询条件的sql依然可以用上该索引。

示例:
SQL> create index t_isc on t(object_id,object_name);
Index created.

SQL>  select object_name from t where object_name is not null;
72920 rows selected.

Execution Plan
----------------------------------------------------------
Plan hash value: 2656528524

--------------------------------------------------------------------------
| Id  | Operation        | Name  | Rows  | Bytes | Cost (%CPU)| Time     |
--------------------------------------------------------------------------
|   0 | SELECT STATEMENT |       | 92167 |  5940K|   429   (1)| 00:00:06 |
|*  1 |  INDEX SKIP SCAN | T_ISC | 92167 |  5940K|   429   (1)| 00:00:06 |
--------------------------------------------------------------------------

到此,关于“oracle中访问索引的方法有哪些”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

oracle中访问索引的方法有哪些

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

sqlserver索引优化的方法有哪些

优化SQL Server索引的方法有以下几种:确保正确选择索引类型:根据查询的特点选择适当的索引类型,包括聚集索引、非聚集索引、唯一索引、稀疏索引等。选择正确的索引列:选择最常用于查询条件和排序的列作为索引列,可以提高查询性能。限制索引列的
sqlserver索引优化的方法有哪些
2024-02-29

VB中数据库访问的方法有哪些

在VB中,可以使用以下方法来访问数据库:ADO(ActiveX Data Objects):ADO是一种用于访问数据库的COM组件,可以在VB中使用ADO来连接和操作数据库。DAO(Data Access Objects):DAO是一种访问
VB中数据库访问的方法有哪些
2024-04-03

python输出索引值的方法有哪些

在Python中,可以使用以下方法输出列表、字符串或元组的索引值:使用for循环遍历列表、字符串或元组,并使用内置的enumerate()函数获取索引值。my_list = [1, 2, 3, 4, 5]for index, value
2023-10-24

php中类的方法的访问权限有哪些

php中类方法的访问权限有三种:1、公有类型(public),在类的内部、子类中或者类的外部都可以使用,不受限制;2、受保护类型(protected);3、私有类型(private),只能在类的内部使用,在类的外部或子类中都无法使用。
2021-09-24

mysql中的索引有哪些

mysql中的索引通过在表中创建数据结构来优化数据检索,提高查询性能。主要索引类型有:b-tree索引:平衡树形结构,适合范围查询。hash索引:哈希表存储,快速查找特定值。fulltext索引:全文搜索。spatial索引:空间数据查找。
mysql中的索引有哪些
2024-04-22

oracle中的索引有哪几种

oracle 支持的索引类型包括:b-tree 索引:用于快速等值、范围和前缀查询hash 索引:用于极快速的等值查询位图索引:用于查询布尔字段函数索引:用于查询函数或表达式产生的列空间索引:用于查询空间数据全文索引:用于搜索文档内容xml
oracle中的索引有哪几种
2024-05-08

oracle索引失效的原因有哪些

有以下几个常见的原因会导致Oracle索引失效:数据分布不均匀:如果索引列的数据分布不均匀,即某些值出现的频率较高,而其他值出现的频率较低,索引的选择性会变低,导致索引失效。统计信息不准确:统计信息是Oracle优化器做出执行计划的基础之一
oracle索引失效的原因有哪些
2024-04-09

java访问数据库的方法有哪些

Java访问数据库的方法有以下几种:1. JDBC(Java Database Connectivity):JDBC是Java访问数据库的标准API,通过JDBC可以连接不同类型的数据库,并执行SQL语句进行数据的增删改查操作。2. ORM
2023-09-22

php访问数据库的方法有哪些

在PHP中,可以使用以下几种方法来访问数据库:1. 使用MySQLi扩展:MySQLi扩展是PHP官方推荐的访问MySQL数据库的方法。它提供了一套面向对象的接口,可以轻松地进行数据库的连接、查询、插入、更新和删除操作。2. 使用PDO扩展
2023-10-10

php数组重新索引的方法有哪些

在PHP中,有以下几种方法可以重新索引数组:1. 使用array_values()函数:该函数返回一个新数组,其中包含原数组的所有值,并以连续整数作为键名。```php$originalArray = array("a", "b", "c"
2023-08-09

编程热搜

目录