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

Oracle数据库中有哪些索引类型

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

北京

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

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

看不清楚,换张图片

免费获取短信验证码

Oracle数据库中有哪些索引类型

今天就跟大家聊聊有关Oracle数据库中有哪些索引类型,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

Oracle数据库中有哪些索引类型

一、B-Tree索引

三大特点:高度较低、存储列值、结构有序

1. 利用索引特性进行优化

  • 外键上建立索引:不但可以提升查询效率,而且可以有效避免锁的竞争(外键所在表delete记录未提交,主键所在表会被锁住)。

  • 统计类查询SQL:count(), avg(), sum(), max(), min()

  • 排序操作:order by字段建立索引

  • 去重操作:distinct

  • UNION/UNION ALL:union all不需要去重,不需要排序

2. 联合索引

应用场景一:SQL查询列很少,建立查询列的联合索引可以有效消除回表,但一般超过3个字段的联合索引都是不合适的.

应用场景二:在字段A返回记录多,在字段B返回记录多,在字段A,B同时查询返回记录少,比如执行下面的查询,结果c1,c2都很多,c3却很少。

select count(1) c1 from t where A = 1; select count(1) c2 from t where B = 2; select count(1) c3 from t where A = 1 and B = 2;

联合索引的列谁在前?

普遍流行的观点:重复记录少的字段放在前面,重复记录多的放在后面,其实这样的结论并不准确。

drop table t purge; create table t as select * from dba_objects; create index idx1_object_id on t(object_id,object_type); create index idx2_object_id on t(object_type,object_id);

等值查询:

select * from t where object_id = 20 and object_type = 'TABLE'; select  * from t where object_id = 20 and object_type = 'TABLE'; select  * from t where object_id = 20 and object_type = 'TABLE';

结论:等值查询情况下,组合索引的列无论哪一列在前,性能都一样。

范围查询:

select * from t where object_id >=20 and object_id < 2000 and object_type = 'TABLE'; select  * from t where object_id >=20 and object_id < 2000 and object_type = 'TABLE'; select  * from t where object_id >=20 and object_id < 2000 and object_type = 'TABLE';

结论:组合索引的列,等值查询列在前,范围查询列在后。  但如果在实际生产环境要确定组合索引列谁在前,要综合考虑所有常用SQL使用索引情况,因为索引过多会影响入库性能。

3. 索引的危害

表上有过多索引主要会严重影响插入性能;

  • 对delete操作,删除少量数据索引可以有效快速定位,提升删除效率,但是如果删除大量数据就会有负面影响;

  • 对update操作类似delete,而且如果更新的是非索引列则无影响。

4. 索引的监控

--监控 alter index [index_name] monitoring usage; select * from v$object_usage; --取消监控:  alter index [index_name] nomonitoring usage;

根据对索引监控的结果,对长时间未使用的索引可以考虑将其删除。

5. 索引的常见执行计划

  • INDEX FULL SCAN:索引的全扫描,单块读,有序

  • INDEX RANGE SCAN:索引的范围扫描

  • INDEX FAST FULL SCAN:索引的快速全扫描,多块读,无序

  • INDEX FULL SCAN(MIN/MAX):针对MAX(),MIN()函数的查询

  • INDEX SKIP SCAN:查询条件没有用到组合索引的第一列,而组合索引的第一列重复度较高时,可能用到

二、位图索引

应用场景:表的更新操作极少,重复度很高的列。

优势:count(*) 效率高

create table t( name_id, gender not null, location not null, age_range not null, data )as select  rownum, decode(floor(dbms_random.value(0,2)),0,'M',1,'F') gender, ceil(dbms_random.value(0,50)) location, decode(floor(dbms_random.value(0,4)),0,'child',1,'young',2,'middle',3,'old') age_range, rpad('*',20,'*') data from dual connect by rownum <= 100000;
create index idx_t on t(gender,location,age_range); create bitmap index gender_idx on t(gender); create bitmap index location_idx on t(location); create bitmap index age_range_idx on t(age_range);
select * from t where gender = 'M' and location in (1,10,30) and age_range = 'child'; select * from t where gender = 'M' and location in (1,10,30) and age_range = 'child';

三、函数索引

应用场景:不得不对某一列进行函数运算的场景。

利用函数索引的效率要低于利用普通索引的。

oracle中创建函数索引即是 你用到了什么函数就建什么函数索引,比如substr

select * from table where 11=1 and substr(field,0,2) in ('01')

创建索引的语句就是

create index indexname on table(substr(fileld,0,2)) online nologging ;

看完上述内容,你们对Oracle数据库中有哪些索引类型有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注亿速云行业资讯频道,感谢大家的支持。

免责声明:

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

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

Oracle数据库中有哪些索引类型

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

下载Word文档

猜你喜欢

oracle索引类型有哪些

oracle索引类型有:1、B-Tree索引;2、位图索引;3、函数索引;4、哈希索引;5、反向键索引;6、局部索引;7、全局索引;8、域索引;9、位图连接索引;10、复合索引。详细介绍:1、B-Tree索引,是一种自平衡的、可以高效地支持
oracle索引类型有哪些
2023-11-16

数据库常用的索引类型有哪些

常用的数据库索引类型包括:1. B-树索引:B-树(Balanced Tree)是一种平衡的多路搜索树,常用于关系型数据库中的索引结构。B-树索引适用于范围查询和等值查询。2. 哈希索引:哈希索引是通过使用哈希函数将索引值映射到哈希表中的存
2023-09-05

oracle数据库类型有哪些

oracle 数据库类型提供不同功能,包括:多模式 (mm)、rac、nosql、autonomous database、exadata、appliance 和 vault。选择合适的类型取决于应用程序和工作负载的要求,包括数据类型、批量、
oracle数据库类型有哪些
2024-04-08

MySQL中有哪些索引类型

本篇文章给大家分享的是有关MySQL中有哪些索引类型,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1.B-Tree索引因为存储引擎不⽤进⾏全表扫描来获取数据,直接从索引的根节点
2023-06-14

Oracle数据库中常见的数据类型有哪些?

Oracle数据库中常见的数据类型有很多种,包括数值型、字符型、日期型等。下面将具体介绍一些常见的数据类型,并附上相应的代码示例。数值型数据类型:NUMBER: 用于存储数值类型数据,可以根据需要指定精度和范围。示例:CREATE TAB
Oracle数据库中常见的数据类型有哪些?
2024-03-08

oracle数据库支持的数据类型有哪些?

oracle 数据库提供多样化数据类型,包括:数字类型:integer、float、double precision、number、dec文本类型:char、varchar2、clob、nclob日期和时间类型:date、time、time
oracle数据库支持的数据类型有哪些?
2024-05-10

Oracle数据库中支持哪些数据类型

在Oracle数据库中支持的数据类型包括:字符型数据类型:CHAR、VARCHAR2、NCHAR、NVARCHAR2、LONG、RAW、LONG RAW、CLOB、NCLOB、BLOB数值型数据类型:NUMBER、FLOAT、BINARY_
Oracle数据库中支持哪些数据类型
2024-04-09

DynamoDB的索引类型有哪些

DynamoDB 的索引类型有两种:局部索引(Local Secondary Index,LSI)和全局索引(Global Secondary Index,GSI)。 局部索引(LSI):局部索引是在表创建时一起创建的索引,它与表的主键是相
DynamoDB的索引类型有哪些
2024-04-09

Oracle数据库中的索引类型及作用详解

Oracle数据库中的索引类型及作用详解在Oracle数据库中,索引是一种非常重要的数据结构,用于快速定位和检索数据,提高查询性能。索引可以大大减少查询数据时需要扫描的表的行数,从而加快查询速度。本文将详细介绍Oracle数据库中常用的索
Oracle数据库中的索引类型及作用详解
2024-03-10

编程热搜

目录