好久没写博客了,这里先转一个老葛整理的《Oracle时间索引的使用需要注意》,先热热身,感觉小细节很有用:
Oracle中我们经常使用Date字段类型记录日期和时间,有的时候还在这个字段上建立索引。
然后通过Java程序访问数据库的时候,我们很自然的类似这样使用:select * from table where endDate>? and endDate<?,然后通过PreparedStatement预编译,再通过setTimestamp传入由java.util.Date转成java.sql.Timestamp的参数(因为java.sql.Date只有日期,java.sql.Time只有时间,所以我们只能用java.sql.Timestamp类型)。我们会认为这样应该走索引区间扫描,效率应该是非常高的。
而事实上,Oracle会把sql解释成如下这样来执行:select * from table where TO_TIMESTAMP(endDate)>? and TO_TIMESTAMP(endDate)<?; 为什么?因为传入的参数是timestamp类型,Oracle从9.2版本以后支持这种类型,所以Oracle做了这样的转换,结果就是这个SQL执行变成了全表扫描。我们做的试验,加了一个index hint,强制走时间索引字段,结果效率也不高,sql执行变成了全索引扫描,和全表扫描没多大区别。结果效率还是低。
不光直接使用JDBC会是这样,Spring,iBatis在处理传入参数是java.util.Date类型的时候,都会使用setTimestamp设定参数,所以都需要注意。
解决办法(四种解决办法,推荐方案一):
1.sql修改成这样:select * from table where endDate>to_date(?,’yyyymmddhh24miss’) and endDate<to_date(?,’yyyymmddhh24miss’);然后将传入参数格式化成对应格式的字符串在传入,这样由Oracle将字符串转成Date类型,就很顺利的走索引区间扫描,效率最高。
2.在建立数据库连接的时候增加一个属性oracle.jdbc.V8Compatible=true,代码如下:
Properties prop=new Properties();
prop.setProperty(“user”,”****”);
prop.setProperty(“password”,”****”);
prop.setProperty(“oracle.jdbc.V8Compatible”,”true”);
Connection connection = DriverManager.getConnection(“jdbc:oracle:thin:@127.0.0.1:1521:test”, prop);
连接池也根据各自的配置方式增加这个属性即可。目前看来这个属性参数是处理时间映射关系的,但是还不确定它是否会带来其他的问题,所以要慎重使用。
3.修改数据库列类型为timestamp类型。
4.依据网上资料,Oracle 11g修改了驱动 api,使用方式可能也会有改变。因为无法试验,所以也不确定具体细节。
分享到:
相关推荐
总的来说,Oracle中的索引使用是一门深奥的学问,涉及到索引的类型选择、创建、维护和优化等多个方面。只有深入理解并熟练掌握这些知识,才能在实际工作中发挥出索引的最大效能,为企业的数据库性能提供有力保障。
- **监控索引使用情况**: 使用Oracle的工具如AWR报告来监控索引的使用情况,识别未被充分利用的索引并进行调整。 - **避免频繁修改索引列**: 对索引列频繁进行UPDATE、INSERT或DELETE操作会导致索引碎片化,影响性能...
Oracle 数据库索引优化方法探析 Oracle 数据库索引优化方法探析是指通过对 Oracle 数据库索引的分析和优化,以提高数据库的查询效率和性能。 Oracle 数据库索引是一种数据结构,用于快速访问数据库表的特定信息。...
合理地创建、管理和优化索引能够显著提高查询性能,降低系统的响应时间,从而提升整个应用程序的效率。本文将从Oracle数据库索引的基础概念出发,深入探讨索引维护的重要性和具体方法。 #### 一、Oracle数据库索引...
Oracle数据库在执行SQL查询时,有时会选择不使用已经创建的索引,这可能是由于多种因素导致的。以下是一些常见的原因及其详细解释: 1. **INDEX SKIP SCAN**: 当创建了一个组合索引,但是查询只使用了索引的非第一...
在Oracle中,通常使用`ALTER INDEX`命令来重建索引,从而消除碎片。具体命令格式如下: ```sql ALTER INDEX ind_1 REBUILD [ONLINE] [TABLESPACE name]; ``` - **ind_1**:待重建的索引名称。 - **ONLINE**:表示...
### Oracle在线建立超大表的索引 #### 需求背景 在Oracle数据库中,为含有千万级别记录的大表创建索引是一项挑战性任务,尤其是对于那些处于高并发在线生产环境中的表。本文将详细介绍如何为一个核心大表(INFO_...
Oracle 在线创建索引和重组索引 Oracle 在线创建索引和重组索引是数据库管理员经常需要处理的问题。在线创建索引可以提高查询性能,而重组索引可以减少索引的碎片化和空间浪费。下面我们将详细介绍在线创建索引和...
### Oracle 创建和删除索引详解 #### 一、Oracle索引...正确地创建和维护索引可以帮助提高数据库性能,降低查询响应时间,并确保系统的高效运行。在实际应用中,还需要根据具体的业务需求和数据特性来调整索引策略。
Oracle数据库的索引机制是数据库优化的关键组成部分,它极大地影响着数据检索的速度和...正确使用索引可以显著提高查询速度,降低响应时间,提升用户体验,但同时也需要平衡索引对写操作的影响,以确保系统的整体性能。
当在WHERE子句中使用了函数或者表达式来处理索引列时,Oracle可能无法有效地利用该索引。例如,使用`SUBSTR`, `DECODE`, `INSTR`等函数来处理索引字段。 **解决办法**: - 尝试重构SQL语句,避免在索引列上使用这些...
### Oracle为何有时不使用索引来查找数据 Oracle数据库在处理SQL查询时,会根据一系列复杂的因素决定是否使用索引以及如何高效地检索数据。本文将深入探讨Oracle在哪些情况下可能会选择不使用索引的原因,并解释...
Oracle 索引详解 Oracle 索引是数据库性能优化的重要工具,它可以大大加快数据的检索速度,提高系统的性能。但是,索引也存在一些缺陷,例如创建索引和维护索引要耗费时间,索引需要占物理空间,等等。在本文中,...
3. **索引使用情况评估**:通过查询`INDEX_STATS`视图可以获取索引的使用情况,包括当前索引中的值数量(`LF_ROWS`)、值长度总和(`LF_ROWS_LEN`)、已被删除的值数量(`DEL_LF_ROWS`)以及被删除的值长度总和(`DEL_LF_...
oracle创建索引很好的参考资料,好的索引能够非常大的提高数据库的查询速度
Oracle数据库中的索引是提升查询性能的关键工具,但随着时间推移和数据操作,索引可能会变得效率低下,需要重建以优化其性能。本文主要总结了重建Oracle索引的相关知识点。 一、重建索引的前提条件 当表上的数据...
CBO(Cost-Based Optimizer):成本基于优化器,这是Oracle数据库查询优化器的一部分,它使用统计信息来评估不同查询执行计划的成本,选择最有效的查询路径。CBO会考虑到索引的存在、索引的统计信息以及表的统计...
要获取所有模式的索引使用情况,需要以SYS用户登录并创建一个自定义视图,例如`v$all_object_usage`,这样可以查看所有索引的所有者、名称、表名以及监控状态等信息。 监控索引使用的重要性在于,它可以帮助DBA优化...
正确选择和设计索引,避免使用限制索引的因素,能显著提高查询性能,减少数据库响应时间,从而提升整个系统的性能。在实践中,需要结合业务需求和查询模式,灵活运用这些知识,进行有效的索引优化。