Oracle性能优化4-索引
Oracle优化可以分为通过改写sql优化和不改写sql优化不改写sql优化一般通过index来实现
在Oracle数据库中,索引按照索引机制的不同,可以分为三种。
1. B-Tree索引 B-Tree index
应用场景: OLTP 使用比较多,处理键值重复率比较低的字段比较适合使用B-Tree索引,处理效率极高。反之当键值重复率很高时,B-Tree索引的效率会非常效。
在Oracle中主键会默认加上B-Tree索引。在Oracle的主键和唯一性约束上 使用B-Tree索引
B-Tree索引又可以分为:唯一索引、组合索引、反向键索引、基于函数的索引。
A. 唯一键索引:
create unique index stu_no_index on t_student(no);
(1). 唯一键索引确保在定义的索引列中没有重复值,
(2). Oracle自动在表的主键列上创建唯一键索引。
(3). 使用CREATE UNIQUE INDEX语句创建唯一键索引。
B. 组合索引:
create index stu_group_index on t_student(class,student);
(1). 组合索引在表的多个列上创建的索引。
(2). 索引中列的顺序是任意的。
(3). 如果SQL语句的WHERE子句中引用了组合索引的所有列或大多数列,则可以提高检索速度。
C. 反向键索引:
create index stu_reverse_index on
t_student(no) reverse;
(1). 反向键索引反转索引列键值的每个字节。
(2). 通常建立在列的值是连续增值的,目的是为了使数据能够均匀的分布在整索引上。
(3). 创建时使用REVERSE关键字。
D. 基于函数的索引:
create or replace function f_minus1(i int)
return int
is
begin
return(i-1);
end;
---建完函数后我们试着建立函数索引,发现建立失败
create index idx_ljb_test on test (f_minus1(object_id));
将会出现如下错误:
ORA-30553: 函数不能确定
将函数加上DETERMINISTIC关键字重建
create or replace function f_minus1(i int)
return int DETERMINISTIC
is
begin
return(i-1);
end;
--现在发现加上DETERMINISTIC关键字后的自定义函数可以建立函数索引成功了!
create index idx_test on test (f_minus1(object_id));
explain plan for select * from test where f_minus1(object_id)=23;
set linesize 1000
select * from table(dbms_xplan.display);
(1). 基于一个或多个列上的函数或表达式创建的索引。
(2). 表达式中不能出现聚合函数。
(3). 不能在LOB类型的列上创建。
(4). 创建时必须有QUERY REWRITE权限。
(5). 一般不推荐使用函数索引
2. 位图索引 Bitmap index
create bitmap index index_name on table_name(column_name);
应用场景:
(1). 处理键值重复率比较高的字段比较适合使用。
(2). 比B-Tree索引更节省空间。
(3). 在OLAP系统中使用比较频繁。当一个表上某个(几个)字段的数值有明显的大量重复时,比如字段是国家、
地区、性别(世界上,或者该字段为其他的一些标识性信息。
(4). 特定类型的查询下性能很高。比如,要对一个结果集进行count操作,特别是在SQL语句的条件部分,在很多字段之间存在
着逻辑“与”、“或”运算的查询方式。
劣势:
(1). 索引列上不适合频繁的进行DML操作。
(2). 值重复率比较低的情况不适合使用。
(3). 位图索引适合在数据仓库中使用,在OLTP中不常使用。
3. 全文索引 Text index
应用场合: 属于数据仓库范畴,在OLTP系统中使用并不广泛。全文索引的优点在于可以对词汇的进行快速搜索。
劣势 :全文索引要 占用 大量的空间
context类型的全文索引是 不基于事务的 无法 实现数据和索引同步。
版权声明:本文为博主原创文章,未经博主允许不得转载。
Oracle性能优化4-索引的更多相关文章
- 【转载】我眼中的Oracle性能优化
我眼中的Oracle性能优化 大家对于一个业务系统的运行关心有如下几个方面:功能性.稳定性.效率.安全性.而一个系统的性能有包含了网络性能.应用性能.中间件性能.数据库性能等等. 今天从数据库性能的角 ...
- 降低磁盘IO使Oracle性能优化(转)
文章转自:http://blog.chinaunix.net/uid-26813519-id-3207996.html 硬件方面虽然只占Oracle性能优化的一个方面(另一方面是软件),但是仍不可忽视 ...
- MySQL 数据库性能优化之索引优化
接着上一篇 MySQL 数据库性能优化之表结构,这是 MySQL数据库性能优化专题 系列的第三篇文章:MySQL 数据库性能优化之索引优化 大家都知道索引对于数据访问的性能有非常关键的作用,都知道索引 ...
- 我眼中的 Oracle 性能优化
恒生技术之眼 作者 林景忠 大家对于一个业务系统的运行关心有如下几个方面:功能性.稳定性.效率.安全性.而一个系统的性能有包含了网络性能.应用性能.中间件性能.数据库性能等等. 今天从数据库性能的角度 ...
- oracle性能优化之awr分析
oracle性能优化之awr分析 作者:bingjava 最近某证券公司系统在业务期间系统运行缓慢,初步排查怀疑是数据库存在性能问题,因此导出了oracle的awr报告进行分析,在此进行记录. 导致系 ...
- Oracle性能优化1-总体思路和误区
最近在看梁敬彬老师关于Oracle性能优化的一些案例,在这里做一些简单的总结 1.COUNT(*)与COUNT(列)哪个更快 drop table t purge; create table t as ...
- Oracle性能优化小结
Oracle性能优化小结 原则一.注意where子句中的连接顺序 Oracle采用自下而上的顺序解析where子句,根据这个原理,表之间的连接必须卸载其他where条件之前,哪些可以滤掉最大数量记录的 ...
- MySQL性能优化:索引
MySQL性能优化:索引 索引提供指向存储在表的指定列中的数据值的指针,然后根据您指定的排序顺序对这些指针排序.数据库使用索引以找到特定值,然后顺指针找到包含该值的行.这样可以使对应于表的SQL语句执 ...
- SQL Server数据库性能优化之索引篇【转】
http://www.blogjava.net/allen-zhe/archive/2010/07/23/326966.html 性能优化之索引篇 近期项目需要, 做了一段时间的SQL Server性 ...
- SQL Server查询性能优化——覆盖索引(二)
在SQL Server 查询性能优化——覆盖索引(一)中讲了覆盖索引的一些理论. 本文将具体讲一下使用不同索引对查询性能的影响. 下面通过实例,来查看不同的索引结构,如聚集索引.非聚集索引.组合索引等 ...
随机推荐
- 如何查看Python对象的属性
在Python语言中,有些库在使用时,在网络上找到的文档不全,这就需要查看相应的Python对象是否包含需要的函数或常量.下面介绍一下,如何查看Python对象中包含哪些属性,如成员函数.变量等,其中 ...
- ArcGIS案例学习笔记-手动编辑擦除挖空挖除相减
ArcGIS案例学习笔记-手动编辑擦除挖空挖除相减 联系方式:谢老师,135-4855-4328,xiexiaokui#qq.com 目的:手动编辑擦除.挖空.挖除.相减 1. 选中内部要素 2. c ...
- trie数的实现
Trie树又称单词查找树,Trie树,是一种树形结构,是一种哈希树的变种.典型应用是用于统计,排序和保存大量的字符串(但不仅限于字符串),所以经常被搜索引擎系统用于文本词频统计.它的优点是:利用字符串 ...
- 历届试题 对局匹配-(dp)
问题描述 小明喜欢在一个围棋网站上找别人在线对弈.这个网站上所有注册用户都有一个积分,代表他的围棋水平. 小明发现网站的自动对局系统在匹配对手时,只会将积分差恰好是K的两名用户匹配在一起.如果两人分差 ...
- 在webpack构建的项目中使用vue
一.复习在普通网页中使用vue1.使用script引入vue2.在index中创建 id为app的容器3.通过new vue得到vm实例二.在webpack中尝试使用vue://注意 : 在webpa ...
- 微信小程序实现滚动分页加载更多
参考网址:https://www.cnblogs.com/Smiled/p/8203306.html 1.wxml: <view class='myScroll' style='float:le ...
- 05_ssm基础(四)之Spring与持久层的整合
30.31.spring对jdbc的支持jdbcTemplate 使用Spring的JDBC准备: 1):拷贝jar: mysql-connector-java-5.1.11.jar:M ...
- Mysql5.6 导出sql文件数据导入到5.7
由于在linux安装了mysql5.7,在需要导入数据时发现报错,说时间默认值不能为0,因为之前用的是mysql5.6 的版本.经过网上百度查找方法,发现是mysql的sql_mode值的问题,于是就 ...
- maven 配置 阿里仓库
<mirror><id>nexus-aliyun</id><mirrorOf>central</mirrorOf><name>N ...
- vi 基本命令使用
vi编辑器是所有Unix及Linux系统下标准的编辑器,它的强大不逊色于任何最新的文本编辑器,这里只是简单地介绍一下它的用法和一小部分指令.由于对 Unix及Linux系统的任何版本,vi编辑器是完全 ...