Oracle 索引的目标是避免全表扫描,提高查询效率,但有些时候却适得其反。例如一张表中有上百万条数据,对某个字段加了索引,但是查询时性能并没有什么提高,这可能是 oracle 索引失效造成的。oracle 索引有一些限制条件,如果你违反了这些索引限制条件,那么即使你已经加了索引,oracle还是会执行一次全表扫描,查询的性能不会比不加索引有所提高,反而可能由于数据库维护索引的系统开销造成性能更差。 下面就是总结的能使 Oracle 索引失效的七大限制条件。
1. 没有 WHERE 子句
2. 使用 IS NULL 和 IS NOT NULL
SELECT ... FROM emp WHERE comm IS NULL; comm 列的索引会失效
3. WHERE 子句中使用函数
如果没有使用基于函数的索引,那么 where 子句中对存在索引的列使用函数时,会使优化器忽略掉这些索引。例如:
select * from staff where trunc(birthdate) = '01-MAY-82';
但是把函数应用在条件上,索引是可以生效的,把上面的语句改成下面的语句,就可以通过索引进行查找。
select * from staff where birthdate < (to_date('01-MAY-82') + 0.9999);
注意:对于 MIN, MAX 函数,Oracle 仍然使用索引。
4. 使用 LIKE ‘%T’ 进行模糊查询
5. WHERE 子句中使用不等于操作
不等于操作包括:<>, !=, NOT colum >= ?, NOT colum <= ?
对于这个限制条件可以通过 OR 替代,例如: colum <> 0 ===> colum>0 OR colum<0
6. 等于和范围索引不会被合并使用
SELECT emp_id, emp_m, salary_q ... FROM emp WHERE job='manager' AND deptno>10
job 和 deptno 都是非唯一索引,这种条件下 oracle 不会合并索引,它只会使用第一个索引。
7. 比较不匹配数据类型
dept_id是一个varchar2型的字段,在这个字段上有索引,但是下面的语句会执行全表扫描。
select * from dept where dept_id = 900198;
这是因为 oracle 会自动把 where 子句转换成 to_number(dept_id)=900198,相当于使用函数,这样就限制了索引的使用。正确写法如下:
select * from dept where dept_id = '900198';
相关推荐
- **尽量避免使用复杂的函数**:在WHERE子句中使用函数可能会导致索引失效,从而降低查询效率。 - **表关联优化**:在进行表关联时,推荐使用直接的表关联而不是存在性检查(EXISTS),以减少查询时间和资源消耗。 -...
3. **避免索引失效**:更新或删除操作可能导致索引失效,需要定期分析和重建索引。 二、SQL优化 1. **编写高效的SQL语句**:避免在WHERE子句中使用否定条件和非谓词,尽量使用JOIN代替子查询,减少嵌套层次。 2. **...
2. 尽量避免在索引列上使用非等值比较(如LIKE、BETWEEN、IN等),这可能导致索引失效。 案例:`SELECT * FROM table WHERE col LIKE 'value%'`,前缀匹配无法利用索引,应考虑使用全文索引或改写为范围查询。 三...
我们需要根据查询模式选择合适的索引类型,如B树索引、位图索引、函数索引等,并注意避免索引失效的情况,如在WHERE子句中使用非前导列或者函数。 四、数据库架构设计 良好的数据库设计能够减少性能瓶颈。这包括...
3. 避免索引失效:定期分析和重建索引,确保其有效性。 四、内存结构优化 1. SGA(System Global Area):包括数据缓冲区缓存、redo日志缓冲区、共享池、PGA(Program Global Area)等,根据系统负载调整各部分大小...
### Oracle数据库日常维护手册知识点概览 #### 一、检查数据库基本状况 ##### 1.1 检查Oracle实例状态 - **SQL命令**: 使用`SELECT instance_name, host_name, startup_time, status, database_status FROM v$...
- **WHERE子句中的连接顺序**:连接顺序同样会影响执行效率,应该优先处理限制条件更严格的WHERE子句。 - **SELECT子句中避免使用‘*’**:使用`SELECT *`会返回表中的所有字段,这可能会消耗更多的I/O资源。建议...
**5.7 定期做统计分析对于采用Oracle Cost-Based Optimizer的系统,需要定期对数据对象的统计信息进行采集更新,使优化器可以根据准备的信息作出正确的explain plan。** - **目的**:确保Oracle CBO优化器基于最新...
- 如果该值设为`TRUE`,`SYSTEM`权限(如`SELECT ANY TABLE`)将不限制对`SYS`模式下各个对象的访问(Oracle7的行为)。这意味着所有具有`SYSTEM`权限的用户都可以访问`SYS`模式下的所有对象,无论这些用户是否拥有...
第一部分 Oracle SQL*PLUS基础 23 第一章 Oracle数据库基础 23 §1.1 理解关系数据库系统(RDBMS) 23 §1.1.1 关系模型 23 §1.1.2 Codd十二法则 24 §1.2 关系数据库系统(RDBMS)的组成 24 §1.2.1 RDBMS 内核 24...
- **方法**: 失效的索引会导致查询性能下降。可以通过 `DBA_INDEXES` 视图并结合 `STATUS` 列来查找这些索引。 **8.5. 检查不起作用的约束** - **方法**: 不起作用的约束会影响数据的一致性。可以使用 `DBA_...
### Oracle10g数据库日常维护手册 #### 一、检查数据库基本状况 ##### 1.1 检查Oracle实例状态 - **目的**: 确保Oracle实例正常运行,并处于活动状态。 - **方法**: 使用`v$instance`视图查询实例的状态。 - **...
"IN"和"OR"可能导致索引失效。若能,尝试将多条件的"OR"改写为UNION ALL,或将"IN"改写为JOIN。 5. **第五掌:尽量去掉"<>"** 使用"<>"可能无法利用索引,改成"NOT = "可能会更好。 6. **第六掌:去掉Where子句...
例如,尽量避免在WHERE子句中使用NOT操作符,因为它可能导致索引失效。 第三,注意SQL的写法。使用JOIN操作时,确保正确指定JOIN条件,并优先选择小表作为驱动表,以减少数据处理量。此外,避免在SELECT语句中使用*...
#### 七、ORACLE数据类型 - **数值型**: - `NUMBER`: 可以表示整数或浮点数。 - `INTEGER`: 整数类型。 - `FLOAT`: 浮点数类型。 - **字符型**: - `VARCHAR2`: 可变长度的字符串。 - `CHAR`: 固定长度的字符串...
3. **避免索引失效**:避免在索引列上使用NOT、IS NULL、!、等操作符,这可能导致索引无法被使用。 二、查询优化 1. **减少JOIN操作**:尽量避免多表JOIN,如果必须使用,确保JOIN条件为索引字段,且JOIN顺序正确。...
同时,应避免在索引列上使用函数,这可能导致索引失效。 3. 表分区:对于大数据量的表,可以使用分区来提高查询性能,例如按时间、ID等进行分区。 四、性能监控与调优 MySQL提供了一系列的性能监控工具,如SHOW ...