Oracle中组合索引的使用详解
来源:互联网 发布:免费淘宝客高佣金采集 编辑:程序博客网 时间:2024/05/22 10:44
在Oracle中可以创建组合索引,即同时包含两个或两个以上列的索引。在组合索引的使用方面,Oracle有以下特点:
1、 当使用基于规则的优化器(RBO)时,只有当组合索引的前导列出现在SQL语句的where子句中时,才会使用到该索引;
2、 在使用Oracle9i之前的基于成本的优化器(CBO)时, 只有当组合索引的前导列出现在SQL语句的where子句中时,才可能会使用到该索引,这取决于优化器计算的使用索引的成本和使用全表扫描的成本,Oracle会自动选择成本低的访问路径(请见下面的测试1和测试2);
3、 从Oracle9i起,Oracle引入了一种新的索引扫描方式——索引跳跃扫描(index skip scan),这种扫描方式只有基于成本的优化器(CBO)才能使用。这样,当SQL语句的where子句中即使没有组合索引的前导列,并且索引跳跃扫描的成本低于其他扫描方式的成本时,Oracle就会使用该方式扫描组合索引(请见下面的测试3);
4、 Oracle优化器有时会做出错误的选择,因为它再“聪明”,也不如我们SQL语句编写人员更清楚表中数据的分布,在这种情况下,通过使用提示(hint),我们可以帮助Oracle优化器作出更好的选择(请见下面的测试4)。
- Oracle中组合索引的使用详解
- Oracle中组合索引的使用详解
- Oracle中组合索引的使用详解
- Oracle中组合索引的使用详解
- Oracle中组合索引的使用详解
- Oracle中组合索引的使用详解
- Oracle中组合索引的使用详解
- Oracle中组合索引的使用详解
- Oracle中组合索引的使用详解
- Oracle中组合索引的使用详解
- Oracle中组合索引的使用详解
- Oracle中组合索引的使用详解
- Oracle中索引的使用
- sql server中使用组合索引需要注意的地方
- 小议在Oracle中索引的使用
- oracle中序列 视图 索引 的 使用
- 在Oracle中索引的使用
- Oracle中索引的创建和使用
- 最小操作数-Java实现
- Erlang 不能错过的盛宴
- 设计模式介绍
- SQL级联删除
- Opencv Python版学习笔记(一)图像直方图
- Oracle中组合索引的使用详解
- Android开发环境搭建
- VIM插件Winmanager buftype问题
- extern &&头文件
- 我的Android学习之旅[1]——Android的系统架构
- Ubuntu13.04 使用guake GUI 显示有错误。
- 使用mysqldump 对数据库进行备份的乱码问题
- 模块化服务规范——OSGI
- windows窗体继承问题