`
学会做人
  • 浏览: 121011 次
  • 性别: Icon_minigender_1
  • 来自: 成都
社区版块
存档分类
最新评论

性能优化之--------索引

阅读更多

一,

oracle的索引陷阱
一个表中有几百万条数据,对某个字段加了索引,但是查询时性能并没有什么提高,这主要可能是oracle的索引限制造成的。
oracle的索引有一些索引限制,在这些索引限制发生的情况下,即使已经加了索引,oracle还是会执行一次全表扫描,查询的性能不会比不加索引有所提高,反而可能由于数据库维护索引的系统开销造成性能更差。
下面是一些常见的索引限制问题。
 
1、使用不等于操作符(<>, !=)
下面这种情况,即使在列dept_id有一个索引,查询语句仍然执行一次全表扫描
select * from dept where staff_num <> 1000;
但是开发中的确需要这样的查询,难道没有解决问题的办法了吗?
有!
通过把用 or 语法替代不等号进行查询,就可以使用索引,以避免全表扫描:上面的语句改成下面这样的,就可以使用索引了。
select * from dept shere staff_num < 1000 or dept_id > 1000;
 
2、使用 is null 或 is not null
使用 is null 或is nuo null也会限制索引的使用,因为数据库并没有定义null值。如果被索引的列中有很多null,就不会使用这个索引(除非索引是一个位图索引,关于位图索引,会在以后的blog文章里做详细解释)。在sql语句中使用null会造成很多麻烦。
解决这个问题的办法就是:建表时把需要索引的列定义为非空(not null)
 
3、使用函数
如果没有使用基于函数的索引,那么where子句中对存在索引的列使用函数时,会使优化器忽略掉这些索引。下面的查询就不会使用索引:
select * from staff where trunc(birthdate) = '01-MAY-82';
但是把函数应用在条件上,索引是可以生效的,把上面的语句改成下面的语句,就可以通过索引进行查找。
select * from staff where birthdate < (to_date('01-MAY-82') + 0.9999);
 
4、比较不匹配的数据类型
比较不匹配的数据类型也是难于发现的性能问题之一。
下面的例子中,dept_id是一个varchar2型的字段,在这个字段上有索引,但是下面的语句会执行全表扫描。
select * from dept where dept_id = 900198;
这是因为oracle会自动把where子句转换成to_number(dept_id)=900198,就是3所说的情况,这样就限制了索引的使用。
把SQL语句改为如下形式就可以使用索引
select * from dept where dept_id = '900198';

 

 

二,

 各种索引使用场合及建议

 

(1)B*Tree索引。

常规索引,多用于oltp系统,快速定位行,应建立于高cardinality列(即列的唯一值除以行数为一个很大的值,存在很少的相同值)。

 Create index indexname on tablename(columnname[columnname...])

(2)反向索引。

B*Tree的衍生产物,应用于特殊场合,在ops环境加序列增加的列上建立,不适合做区域扫描。

 Create index indexname on tablename(columnname[columnname...]) reverse

(3)降序索引。

B*Tree的衍生产物,应用于有降序排列的搜索语句中,索引中储存了降序排列的索引码,提供了快速的降序搜索。

 Create index indexname on tablename(columnname DESC[columnname...])

(4)位图索引。

位图方式管理的索引,适用于OLAP(在线分析)和DSS(决策处理)系统,应建立于低cardinality列,
适合集中读取,不适合插入和修改,提供比B*Tree索引更节省的空间。

 Create BITMAP index indexname on tablename(columnname[columnname...])

在实际应用中,如果某个字段的值需要频繁更新,那么就不适合在它上面创建位图索引。
在位图索引中,如果你更新或插入其中一条数值为N的记录,
那么相应表中数值为N的记录(可能成百上千条)全部被Oracle锁定,
这就意味着其它用户不能同时更新这些数值为N的记录,其它用户必须要等第一个用户提交后,
才能获得锁,更新或插入数据,bitmap index它主要用于决策支持系统或静态数据。

(5)函数索引。

B*Tree的衍生产物,应用于查询语句条件列上包含函数的情况,
索引中储存了经过函数计算的索引码值。可以在不修改应用程序的基础上能提高查询效率。

索引创建策略
1.导入数据后再创建索引
2.不需要为很小的表创建索引
3.对于取值范围很小的字段(比如性别字段)应当建立位图索引
4.限制表中的索引的数目
5.为索引设置合适的PCTFREE值
6.存储索引的表空间最好单独设定

唯一索引和不唯一索引都只是针对B树索引而言.
Oracle最多允许包含32个字段的复合索引
由此估计出一个查询如果使用某个索引会需要读入的数据块块数。
需要读入的数据块越多,则 cost 越大,Oracle 也就越有可能不选择使用 index

 

三,

能用唯一索引,一定用唯一索引
能加非空,就加非空约束
一定要统计表的信息,索引的信息,柱状图的信息。
联合索引的顺序不同,影响索引的选择,尽量将值少的放在前面
只有做到以上四点,数据库才会正确的选择执行计划。

分享到:
评论
1 楼 gordonAtJava 2009-06-23  
1、使用不等于操作符(<>, !=)
下面这种情况,即使在列dept_id有一个索引,查询语句仍然执行一次全表扫描
select * from dept where staff_num <> 1000;
但是开发中的确需要这样的查询,难道没有解决问题的办法了吗?
有!
通过把用 or 语法替代不等号进行查询,就可以使用索引,以避免全表扫描:上面的语句改成下面这样的,就可以使用索引了。
select * from dept shere staff_num < 1000 or dept_id > 1000;

这个例子不是很妥吧,数据库怎么跑执行计划,主要还是看io,你这个sql里面要的数据除了 staff_num=1000的其他都要,走索引只会更慢。

相关推荐

    数据库_性能优化篇-2(1).docx

    - 自增主键:每个表中应包含一个自增主键,如user_id,有助于保证数据的唯一性和优化索引。 - 避免NULL字段:尽量避免使用NULL字段,因为它们不利于查询优化,且在索引中占用额外空间。 5. **数据库范式**: - ...

    MySql性能优化集合--满满的干货

    ### MySQL性能优化集合 #### 一、MySQL优化概述 MySQL作为一种广泛使用的开源关系型数据库管理系统,在数据处理方面表现优秀。然而,在高并发、大数据量的情况下,可能会遇到性能瓶颈。因此,进行MySQL性能优化是...

    mysql面试题-mysql经典面试题目-数据库的基本概念-SQL语法-事务处理-索引优化-性能调优-mysql-面试题目

    【MySQL面试题】在面试MySQL相关的职位时,面试官可能会问到一系列关于数据库基础、SQL语法、事务处理、索引优化以及性能调优的问题。以下是一些可能的面试重点: 1. **数据库基本概念**: - 数据库是用于存储和...

    Oracle-性能优化之-表设计(与“数据”有关文档共15张).pptx

    Oracle数据库的性能优化是数据库管理员和开发人员关注的重要议题,特别是在大数据量的环境下。本文件主要探讨了如何通过表的设计来提升Oracle数据库的性能,主要包括堆表、索引组织表和聚簇表三种表结构。 1. **堆...

    SQL优化-索引(1-15).rar

    "SQL优化-索引10.htm"可能涉及了索引在并发操作中的影响,如锁定和行版本控制,以及如何在高并发环境中优化索引策略,以减少锁争用和提高系统并发性能。 综上所述,这个压缩包文件提供了全面的SQL Server索引优化...

    mysql性能优化篇-自己的理解

    根据给定文件的信息,我们可以提炼出关于MySQL性能优化的关键知识点,并进行详细阐述: ### 一、MySQL的认识 #### 1.1 架构与组成部分 MySQL作为一款广泛使用的开源关系型数据库管理系统,其架构主要分为客户端和...

    mysql性能优化-慢查询分析、优化索引和配置.doc

    本文将详细探讨慢查询分析、优化索引以及MySQL的配置优化。 一、优化概述 MySQL性能优化的目标是减少CPU和I/O的瓶颈。CPU瓶颈通常发生在数据加载到内存或从硬盘读取时,而I/O瓶颈则发生在数据量超过内存容量的情况...

    SQL查询优化--索引的使用与管理[收集].pdf

    SQL查询优化是一个重要的数据库管理任务,它...综上所述,了解并熟练掌握SQL查询优化和索引管理对于提升数据库性能至关重要。正确使用索引、理解和分析执行计划以及适时维护索引都可以显著改善数据库系统的整体效率。

    SQL优化-索引

    ### SQL优化之索引详解 #### 一、SQL概述及分类 SQL,即Structured Query Language,是一种用于管理和处理关系型数据库的标准语言。SQL主要由以下几个部分组成: 1. **数据定义语言(Data Definition Language, ...

    mssql索引优化工具

    SQL Server(简称MSSQL)是一款广泛应用的企业级关系型数据库管理系统,其性能优化是数据库管理员(DBA)的重要工作之一。索引作为提升查询性能的关键工具,对于大型数据库来说尤其重要。"mssql索引优化工具"是一种...

    ORACLE-SQL性能优化大全.pdf

    ### ORACLE-SQL性能优化大全知识点详述 #### 一、优化基础知识概述 - **性能管理**: - **尽早开始**:性能优化应该在项目的早期就开始考虑,而不是等到后期出现性能瓶颈时才去处理。 - **设立合适目标**:设定...

    性能调优专题 -Mysql索引优化与底层数据结构深入剖析

    性能调优专题_-Mysql索引优化与底层数据结构深入剖析

    mysql查询优化之索引优化

    优化索引的关键在于合理设计和应用。以下是一些核心策略: - **选择合适的索引列**:索引应该建在经常出现在WHERE子句、JOIN条件和ORDER BY子句中的列上。 - **避免过度索引**:过多的索引会增加写操作的开销,...

    Microsoft SQL Server 性能调校 -- 源代码

    在IT领域,数据库管理系统是企业数据存储和处理的核心,而Microsoft SQL Server作为一款广泛应用的关系型数据库,其性能优化至关重要。本资源"Microsoft SQL Server 性能调校 -- 源代码"聚焦于如何通过源代码层面...

    数据库性能优化方案

    综上所述,数据库性能优化是一个涉及多方面的复杂工程,需要结合具体业务场景和数据库特性,通过索引优化、查询优化、存储引擎选择、资源管理等多种手段进行综合调整。文件“数据库性能优化方案.htm”和“数据库性能...

    Mysql性能优化教程.doc

    ### MySQL性能优化教程知识点概述 #### 一、MySQL执行优化 **1.1 背景及目标** - **背景**: 针对已具备一定MySQL使用经验的工程师,特别是适用于高并发、海量数据处理的互联网环境。 - **目标**: 通过对MySQL性能...

    ORACLE存储过程性能优化技巧

    ### ORACLE存储过程性能优化技巧 #### 一、概述 在数据库管理中,ORACLE存储过程的性能优化是一项至关重要的工作。高效的存储过程不仅能提升应用系统的响应速度,还能减少服务器资源的消耗,提高整体系统性能。...

    MySQL性能优化概述

    本文将深入探讨MySQL性能优化的关键方面,包括硬件与软件环境的选择、数据表设计、索引管理、SQL语句优化以及存储引擎的选择等。 #### MySQL调优概述 MySQL性能优化涉及多个层面,包括但不限于: - **硬件与软件...

Global site tag (gtag.js) - Google Analytics