`
lvwenwen
  • 浏览: 959118 次
  • 性别: Icon_minigender_1
  • 来自: 魔都
社区版块
存档分类
最新评论

ORACLE-SQL性能优化

阅读更多

ORACLE-SQL性能优化

博客分类:
 

ORACLE-SQL性能优化

 

   作者:张小飞 iteye账号:z_xiaofei168

 

 

SQL语句优化是提高性能的重要环节

n  开发人员不能只注重功能的实现,不管性能如何

n  开发人员不能把Oracle当成一个黑盒子,必须了解其结构、处理SQL和数据的方法

n  必需遵守既定的开发规范

访问数据表的方式

全表扫描

全表扫描就是顺序地访问表中每条记录。Oracle采用一次读入多个数据块(database block)的方式优化全表扫描。

通过ROWID访问表

ROWID包含了表中记录的物理位置信息。可以采用基于ROWID的访问方式情况提高访问表的效率。Oracle采用索引实现了数据和存放数据的物理位置(ROWID)之间的联系通常索引提供了快速访问ROWID的方法,因此那些基于索引列的查询就可以得到性能的提高。

SQL Tunning 的重点

n  SQL: insert, update, delete, select;

n  主要关注的是select

n  关注的是:如何用最小的硬件资源消耗、最少的响应时间定位数据位置

SQL Tunning Tips

sql 语句的编写原则和优化

随着数据库中数据的增加,系统的响应速度就成为目前系统需要解决的最主要的问题之一。系统优化中一个很重要的方面就是SQL语句的优化。对于大量数据,劣质SQL语句和优质SQL语句之间的速度差别可以达到上百倍,对于一个系统不是简单地能实现其功能就可,而是要写出高质量的SQL语句,提高系统的可用性。

sql 语句的编写原则和优化

n  在编写SQL语句时我们应清楚优化器根据何种原则来使用索引,这有助于写出高性能的SQL语句。

n  SQL语句的编写原则和SQL语句的优化,请跟我一起学习以下几方面:

1.不要让Oracle做得太多;

2.给优化器更明确的命令;

3.减少访问次数;

4.细节上的影响;

一、不要让Oracle做得太多

1、避免复杂的多表关联,如:

select …from user_files uf, df_money_files dm, cw_charge_record cc

where uf.user_no = dm.user_no

and dm.user_no = cc.user_no

and ……

and not exists(select …)

2、避免使用“*

当你想在SELECT子句中列出所有的COLUMN,使用动态SQL列引用*是一个方便的方法.不幸的是,这是一个非常低效的方法实际上,ORACLE在解析的过程中会将‘*依次转换成所有的列名这个工作是通过查询数据字典完成的这意

味着将耗费更多的时间;

3、避免使用耗费资源的操作

带有DISTINCT,UNION,MINUS,INTERSECT,ORDER BYSQL语句会启动SQL引擎执行耗费资源的排序(SORT)功能DISTINCT需要一次排序操作而其他的至少需要执行两次排序.例如,一个UNION查询,其中每个查询都带有GROUP BY子句, GROUP BY会触发嵌入排序(NESTED SORT) ;这样每个查询需要执行一次排序然后在执行UNION又一个唯一排序(SORT UNIQUE)操作被执行而且它只能在前面的嵌入排序结束后才能开始执行嵌入的排序的深度会大大影响查询的效率.通常带有UNION, MINUS , INTERSECTSQL语句都可以用其他方式重写.

4、用EXISTS替换DISTINCT,例如:

低效:

    SELECT DISTINCT DEPT_NO,DEPT_NAME

    FROM DEPT D,EMP E

    WHERE D.DEPT_NO = E.DEPT_NO

高效:

    SELECT DEPT_NO,DEPT_NAME

    FROM DEPT D

    WHERE EXISTS ( SELECT ‘X’ FROM EMP E WHERE E.DEPT_NO = D.DEPT_NO);

UNION-ALL 替换UNION ( if possible)

SQL语句需要UNION两个查询结果集合时,这两个结果集合会以UNION-ALL的方式被合并然后在输出最终结果前进行排序.

低效:

   SELECT ACCT_NUM, BALANCE_AMT

        FROM DEBIT_TRANSACTIONS

        WHERE TRAN_DATE = ’31-DEC-95’

        UNION

        SELECT ACCT_NUM, BALANCE_AMT

        FROM DEBIT_TRANSACTIONS

        WHERE TRAN_DATE = ’31-DEC-95’

高效:

        SELECT ACCT_NUM, BALANCE_AMT

        FROM DEBIT_TRANSACTIONS

        WHERE TRAN_DATE = ’31-DEC-95’

        UNION ALL

        SELECT ACCT_NUM, BALANCE_AMT

        FROM DEBIT_TRANSACTIONS

        WHERE TRAN_DATE = ’31-DEC-95’

二、给优化器更明确的命令

                   1、避免在索引列上使用计算函数

         WHERE子句中,如果索引列是函数的一部分.优化器将不使用索引而使用全表扫描.举例:

低效:

SELECT … FROM DEPT WHERE SAL * 12 > 25000;

高效:

SELECT … FROM DEPT WHERE SAL > 25000/12;

2、避免使用前置通配符

WHERE子句中如果索引列所对应的值的第一个字符由通配符(WILDCARD)开始索引将不被采用.

SELECT USER_NO,USER_NAME,ADDRESS FROM USER_FILES WHERE USER_NO LIKE '%109204421';

                 在这种情况下,ORACLE将使用全表扫描.

         在很多情况下可能无法避免这种情况,但是一定要心中有底,通配符如此使用会降低查询速度。然而当通配符出现在字符串其他位置时,优化器就能利用索引。在下面的查询中索引得到了使用:

select * from employee where last_name like 'c%';

                   3、避免在索引列上使用NOT

通常,我们要避免在索引列上使用NOT, NOT会产生在和在索引列上使用函数相同的影响.ORACLE遇到NOT,他就会停止使用索引转而执行全表扫描.举例:

低效: (这里,不使用索引)

   SELECT … FROM DEPT WHERE DEPT_CODE NOT = 0;

高效: (这里,使用了索引)

   SELECT … FROM DEPT WHERE DEPT_CODE > 0;

                   4、避免在索引列上使用 IS NULLIS NOT NULL

         避免在索引中使用任何可以为空的列,ORACLE将无法使用该索引.对于单列索引,如果列包含空值,索引中将不存在此记录对于复合索引,如果每个列都为空,索引中同样不存在此记录. 如果至少有一个列不为空,则记录存在于索引中.如果唯一性索引建立在表的A列和B列上并且表中存在一条记录的A,B值为(123,null) , ORACLE将不接受下一条具有相同A,B值(123,null)的记录(插入). 然而如果所有的索引列都为空,ORACLE将认为整个键值为空而空不等于空因此你可以插入1000条具有相同键值的记录,当然它们都是空!因为空值不存在于索引列中,所以WHERE子句中对索引列进行空值比较将使ORACLE停用该索引.任何在where子句中使用is nullis not null的语句优化器是不允许使用索引的。

三、减少访问次数

         当执行每条SQL语句时, ORACLE在内部执行了许多工作解析SQL语句估算索引的利用率绑定变量 , 读数据块等等由此可见减少访问数据库的次数 , 就能实际上减少ORACLE的工作量.类比,工程实施。

四、细节上的影响

         1WHERE子句中的连接顺序

           ORACLE采用自下而上的顺序解析WHERE子句,根据这个原理当在WHERE子句中有多个表联接时,WHERE子句中排在最后的表应当是返回行数可能最少的表,有过滤条件的子句应放在WHERE子句中的最后。

n  如:设从emp表查到的数据比较少或该表的过滤条件比较确定,能大大缩小查询范围,则将最具有选择性部分放在WHERE子句中的最后:

select * from emp e,dept d where d.deptno >10 and e.deptno =30 ;

n  如果dept表返回的记录数较多的话,上面的查询语句会比下面的查询语句响应快得多。

select * from emp e,dept d where e.deptno =30 and d.deptno >10 ;

2WHERE子句 ——函数、表达式使用

最好不要在WHERE子句中使用函或表达式,如果要使用的话,最好统一使用相同的表达式或函数,这样便于以后使用合理的索引

3Order by语句

n  ORDER BY语句决定了Oracle如何将返回的查询结果排序。Order by语句对要排序的列没有什么特别的限制,也可以将函数加入列中(象联接或者附加等)。任何在Order by语句的非索引项或者有计算表达式都将降低查询速度。

n  仔细检查order by语句以找出非索引项或者表达式,它们会降低性能。解决这个问题的办法就是重写order by语句以使用索引,也可以为所使用的列建立另外一个索引,同时应绝对避免在order by子句中使用表达式。

4>= 替代 >

如果DEPTNO上有一个索引。

         高效:

          SELECT * ROM EMP HERE DEPTNO >=4

         低效:

        SELECT * ROM EMP HERE DEPTNO >3

5通过使用>=<=等,避免使用NOT命令

例子:select * from employee where salary <> 3000;

对这个查询,可以改写为不使用NOT

select * from employee where salary<3000 or salary>3000;

         虽然这两种查询的结果一样,但是第二种查询方案会比第一种查询方案更快些。第二种查询允许Oraclesalary列使用索引,而第一种查询则不能使用索引。

分享到:
评论

相关推荐

    ORACLE-SQL性能优化大全.pdf

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

    ORACLE-SQL性能优化(这个很全的)

    ORACLE-SQL性能优化(这个很全的),ORACLE SQL语句优化!

    ORACLE-SQL性能优化(这个很全的).ppt

    ORACLE-SQL性能优化(这个很全的).ppt

    ORACLE-SQL性能优化(内部培训资料).docx

    ### ORACLE-SQL性能优化关键知识点 #### 一、选用适合的Oracle优化器 在Oracle数据库中,优化器的选择对于SQL语句的执行效率至关重要。根据文档提供的信息,Oracle提供了三种主要的优化器:基于规则的优化器(RULE)...

    Oracle-SQL性能优化及案例分析.ppt

    Oracle SQL性能优化是数据库管理员和开发人员关注的重要领域,它涉及到如何提高SQL查询的执行效率,减少资源消耗,提升系统整体性能。Oracle数据库提供了多种工具和技术来帮助优化SQL语句。 首先,Oracle有两种主要...

    老方块ORACLE SQL性能优化(全)教学PPT

    性能管理 性能问题 调整的方法 SQL优化机制 应用的调整 SQL语句的处理过程 共享SQL区域 SQL语句处理的阶段 共享游标 SQL编码标准 Oracle 优化器介绍 SQL Tunning Tips 优化Tools

    ORACLE SQL性能优化系列

    ORACLE SQL性能优化系列 ORACLE SQL性能优化是数据库管理员和开发者非常关心的一个话题。为了提高数据库的性能,ORACLE 提供了多种优化技术。下面我们将详细介绍 ORACLE SQL 性能优化系列中的一些重要知识点。 一...

    ORACLE-SQL优化

    ORACLE-SQL优化是一个涉及广泛技术细节和策略的领域。在优化SQL语句执行过程时,了解ORACLE优化器的工作机制,表之间的关联方式,以及如何获取和分析SQL执行计划是至关重要的。以下,我们将详细介绍ORACLE-SQL优化的...

    Oracle_SQL性能优化.

    Oracle_SQL性能优化.

    Oracle数据库SQL性能优化

    Oracle数据库SQL性能优化学习可以用到的。

    dba-oracle-sql优化.

    Oracle SQL优化是数据库管理员(DBA)在提升系统性能、减少资源消耗方面的重要工作。SQL优化涉及多个层面,包括查询优化、索引优化、表设计优化以及存储过程和触发器的优化。以下是对"dba-oracle-sql优化"这一主题的...

    ORACLE_SQL性能优化(全).ppt

    【Oracle SQL性能优化】 Oracle SQL性能优化是数据库开发人员必须掌握的关键技能,它涉及到SQL语句的编写、执行过程、优化器的选择以及执行计划的分析等多个方面。在Oracle数据库环境中,优化SQL性能对于提升系统...

    ORACLE培训--sql性能优化(老方块内部培训班使用)

    课程主要讨论:SQL语句执行的过程、ORACLE优化器 ,表之间的关联,如何得到SQL执行计划,如何分析执行计划等内容,从而由浅到深的方式了解SQL优化的过 程,使大家逐步掌握SQL优化。目录: 优化基础知识 性能调整...

    oracle-sql优化

    【Oracle SQL优化】是数据库管理中的重要环节,旨在提高系统的整体性能。SQL优化涉及多个方面,包括理解SQL语句的处理过程、...在整个过程中,开发人员不仅要关注功能实现,还要重视性能优化,确保系统的稳定高效运行。

    Oracle+SQL性能优化40条.docx

    Oracle SQL 性能优化 40 条 以下是 Oracle SQL 性能优化 40 条的知识点总结: 一、SQL 语句执行步骤 * 语法分析:检查 SQL 语句的语法正确性 * 语义分析:分析 SQL 语句的逻辑含义 * 视图转换:将 SQL 语句转换为...

    Oracle 11g-SQL-优化

    4. SQL性能分析工具:Oracle 11g提供了多种性能分析工具,包括自动工作负载存储库(AWR)、SQL调优顾问和SQL监视器等。这些工具可以帮助DBA和开发人员识别和解决性能问题。 5. SQL执行计划的理解:通过执行计划,我们...

    Oracle-SQL优化.docx

    二、 SQL 语句性能优化 2.1 选用合适的 ORACLE 优化器 在优化 SQL 语句时,需要选用合适的 ORACLE 优化器。不同的优化器可以带来不同的优化效果。 2.2 访问 Table 的方式 在优化 SQL 语句时,需要注意访问 Table...

Global site tag (gtag.js) - Google Analytics