`

Oracle 索引失效的七大限制条件

阅读更多
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';
分享到:
评论

相关推荐

    oracle 性能优化 加快查询效率

    - **尽量避免使用复杂的函数**:在WHERE子句中使用函数可能会导致索引失效,从而降低查询效率。 - **表关联优化**:在进行表关联时,推荐使用直接的表关联而不是存在性检查(EXISTS),以减少查询时间和资源消耗。 -...

    Oracle_ziliao.rar_oracle

    3. **避免索引失效**:更新或删除操作可能导致索引失效,需要定期分析和重建索引。 二、SQL优化 1. **编写高效的SQL语句**:避免在WHERE子句中使用否定条件和非谓词,尽量使用JOIN代替子查询,减少嵌套层次。 2. **...

    Oracle查询优化改写技巧与案例

    2. 尽量避免在索引列上使用非等值比较(如LIKE、BETWEEN、IN等),这可能导致索引失效。 案例:`SELECT * FROM table WHERE col LIKE 'value%'`,前缀匹配无法利用索引,应考虑使用全文索引或改写为范围查询。 三...

    Oracle 性能调优向导

    我们需要根据查询模式选择合适的索引类型,如B树索引、位图索引、函数索引等,并注意避免索引失效的情况,如在WHERE子句中使用非前导列或者函数。 四、数据库架构设计 良好的数据库设计能够减少性能瓶颈。这包括...

    oracle性能优化文档

    3. 避免索引失效:定期分析和重建索引,确保其有效性。 四、内存结构优化 1. SGA(System Global Area):包括数据缓冲区缓存、redo日志缓冲区、共享池、PGA(Program Global Area)等,根据系统负载调整各部分大小...

    Oracle数据库日常维护手册.pdf

    ### Oracle数据库日常维护手册知识点概览 #### 一、检查数据库基本状况 ##### 1.1 检查Oracle实例状态 - **SQL命令**: 使用`SELECT instance_name, host_name, startup_time, status, database_status FROM v$...

    Oracle SQL性能优化.doc

    - **WHERE子句中的连接顺序**:连接顺序同样会影响执行效率,应该优先处理限制条件更严格的WHERE子句。 - **SELECT子句中避免使用‘*’**:使用`SELECT *`会返回表中的所有字段,这可能会消耗更多的I/O资源。建议...

    Oracle DBA日常巡检最佳实践

    - **目的**:发现并修复失效的索引,提高查询性能。 - **方法**:使用`DBA_INDEXES`视图来检查索引的状态。 **7.5 检查不起作用的约束** - **目的**:识别并解决无效的约束,确保数据完整性。 - **方法**:通过...

    Oracle初始化参数

    - 如果该值设为`TRUE`,`SYSTEM`权限(如`SELECT ANY TABLE`)将不限制对`SYS`模式下各个对象的访问(Oracle7的行为)。这意味着所有具有`SYSTEM`权限的用户都可以访问`SYS`模式下的所有对象,无论这些用户是否拥有...

    Oracle8i_9i数据库基础

    第一部分 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...

    ORACLE数据库日常工作维护知识总结.pdf

    - **方法**: 失效的索引会导致查询性能下降。可以通过 `DBA_INDEXES` 视图并结合 `STATUS` 列来查找这些索引。 **8.5. 检查不起作用的约束** - **方法**: 不起作用的约束会影响数据的一致性。可以使用 `DBA_...

    优化sql语句执行效率几点注意事项

    例如,尽量避免在WHERE子句中使用NOT操作符,因为它可能导致索引失效。 第三,注意SQL的写法。使用JOIN操作时,确保正确指定JOIN条件,并优先选择小表作为驱动表,以减少数据处理量。此外,避免在SELECT语句中使用*...

    Oracle数据库基础

    #### 七、ORACLE数据类型 - **数值型**: - `NUMBER`: 可以表示整数或浮点数。 - `INTEGER`: 整数类型。 - `FLOAT`: 浮点数类型。 - **字符型**: - `VARCHAR2`: 可变长度的字符串。 - `CHAR`: 固定长度的字符串...

    sql语句之降龙十八掌

    "IN"和"OR"可能导致索引失效。若能,尝试将多条件的"OR"改写为UNION ALL,或将"IN"改写为JOIN。 5. **第五掌:尽量去掉"&lt;&gt;"** 使用"&lt;&gt;"可能无法利用索引,改成"NOT = "可能会更好。 6. **第六掌:去掉Where子句...

    SQL.zip_sql优化

    3. **避免索引失效**:避免在索引列上使用NOT、IS NULL、!、等操作符,这可能导致索引无法被使用。 二、查询优化 1. **减少JOIN操作**:尽量避免多表JOIN,如果必须使用,确保JOIN条件为索引字段,且JOIN顺序正确。...

    MYSQL数据库

    同时,应避免在索引列上使用函数,这可能导致索引失效。 3. 表分区:对于大数据量的表,可以使用分区来提高查询性能,例如按时间、ID等进行分区。 四、性能监控与调优 MySQL提供了一系列的性能监控工具,如SHOW ...

Global site tag (gtag.js) - Google Analytics