Oracle使用强制索引的方法与注意事项
Oracle使用强制索引
在一些场景下,可能ORACLE不会自动走索引,这时候,如果对业务清晰,可以尝试使用强制索引,测试查询语句的性能。
以EMP表为例:
先在EMP表中建立唯一索引,如图。
普通搜索:
SELECT * FROM EMP T
查看执行计划:
可以看到,是走的全表扫描。
使用强制索引,在SELECT 后面加上/* .*/ 中间加上索引的属性,代码如下:
SELECT /*+index(t pk_emp)*/* FROM EMP T
强制索引,/* ..*/第一个星星后不能有空格,里边内容结构为:加号index(表名 空格 索引名)。
如果表用了别名,注释里的表也要使用别名。
可以看到,这是走的是索引PK_EMP。
Oracle使用强制索引注意事项
最近对Oracle的SQL索引生效条件进行了验证,发现如下规律,记录如下:
1、索引生效与记录的条数相关
a、2016-01-01~2016-11-30 数据量402518,索引生效
b、2016-01-01~2016-12-30 数据量444844,索引不生效
SELECT
*
FROM
T_MAINS
WHERE
date TO_DATE ( 备注今天是2017-01-23
2016-01-01 ,
yyyy-mm-dd hh24:mi:ss
)
AND date TO_DATE (
2016-11-30 ,
yyyy-mm-dd hh24:mi:ss
);
2、T_MAINS已根据某个时间类型的字段进行分区,查询条件中如果能够精准定位到某个分区,可以提高SQL的执行效率
Oracle使用强制索引
在一些场景下,可能ORACLE不会自动走索引,这时候,如果对业务清晰,可以尝试使用强制索引,测试查询语句的性能。
以EMP表为例:
先在EMP表中建立唯一索引,如图。
普通搜索:
SELECT * FROM EMP T
查看执行计划:
可以看到,是走的全表扫描。
使用强制索引,在SELECT 后面加上/* .*/ 中间加上索引的属性,代码如下:
SELECT /*+index(t pk_emp)*/* FROM EMP T
强制索引,/* ..*/第一个星星后不能有空格,里边内容结构为:加号index(表名 空格 索引名)。
如果表用了别名,注释里的表也要使用别名。
可以看到,这是走的是索引PK_EMP。
Oracle使用强制索引注意事项
最近对Oracle的SQL索引生效条件进行了验证,发现如下规律,记录如下:
1、索引生效与记录的条数相关
a、2016-01-01~2016-11-30 数据量402518,索引生效
b、2016-01-01~2016-12-30 数据量444844,索引不生效
SELECT
*
FROM
T_MAINS
WHERE
date TO_DATE ( 备注今天是2017-01-23
2016-01-01 ,
yyyy-mm-dd hh24:mi:ss
)
AND date TO_DATE (
2016-11-30 ,
yyyy-mm-dd hh24:mi:ss
);
2、T_MAINS已根据某个时间类型的字段进行分区,查询条件中如果能够精准定位到某个分区,可以提高SQL的执行效率
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。
我想要获取技术服务或软件
服务范围:MySQL、ORACLE、SQLSERVER、MongoDB、PostgreSQL 、程序问题
服务方式:远程服务、电话支持、现场服务,沟通指定方式服务
技术标签:数据恢复、安装配置、数据迁移、集群容灾、异常处理、其它问题
本站部分文章参考或来源于网络,如有侵权请联系站长。
数据库远程运维 Oracle使用强制索引的方法与注意事项
相关文章
- Oracle 等待事件 sbtbufinfo 官方解释,作用,如何使用及优化方法
- Oracle生成随机数的简单方法(oracle生成随机数)
- 中的表查看Oracle数据库中所有表的方法(oracle显示所有数据库)
- Oracle中调整数据精度的方法(oracle设置精度)
- 处理Oracle索引:加速并行处理(oracle索引并行)
- 掌握Oracle数据库:快速查询代码的技巧(oracle代码查询)
- 使用Oracle触发器完成数据库操作(oracle触发器类型)
- 上传文件到Oracle数据库的方法(oracle上传文件)
- Oracle数据库中创建索引的基本语句(oracle建索引语句)
- Oracle如何支持繁体字处理——使用技巧和实践方法(oracle繁体字)
- Oracle转换为整型数据的方法(oracle转整型)
- 如何用 Oracle 提取日期信息?(oracle 时间取日期)
- Oracle数据库内存结构深度剖析(oracle内存结构分类)
- GIS连接Oracle数据库失败排查方法及解决方案(gis连oracle失败)
- Oracle中实现复杂的周期管理(oracle中算周期)
- Oracle 检索探索新的知识之旅(oracle 什么是检索)
- Oracle主键索引损坏恢复之路(oracle主键失效恢复)
- Oracle存储过程传递多个参数的实现方法(oracle传多个参数)
- 调整Oracle会话的最佳空闲时间(oracle会话空闲时间)
- 方法Oracle数据库清除实践深入解析清除数据的方法(oracle中清除数据的)
- 查询深入了解Oracle数据库中模糊与精准查询(oracle中模糊和精准)
- Oracle数据库实现的右关联(oracle 中右关联)
- 字符从Oracle数据库中截取左侧字符的方法(oracle中从左截取)
- 数据库Oracle中两表计算总数的方法(oracle 两表取总数)
- Oracle无需担忧无需的服务架构(oracle不需要的服务)
- Oracle多列更新的神奇魅力(oracle一次修改多列)
- Oracle建立二进制文件索引的方法