网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
本月文章推荐
.Oracle数据库管理系统:大数据的.
.Oracle中三种上载文件技术(二).
.高手的Oracle大批量删除数据方法.
.Oracle数据库常见问题答疑一.
.Oracle产品中的错误的诊断.
.Oracle9i新特性:iSQLPLUS.
.oracle9i,如何在PL/SQL中读写文.
.Mandrake9.0的启动过程(从init开.
.由浅入深讲解Oracle数据库的备份.
.如何才能在同一台机器配置两个li.
.如何在Oracle中使用游标来实现多.
.一些 schema 的常用脚本归类介绍.
.将Oracle内置的安全特性用于PHP.
.Oracle 9i 数据库管理实务讲座(一.
.Oracle 9i产品文档.
.如何使用Oracle的Decode函数进行.
.Oracle10g中新的SQLoptimizerhin.
.PL/SQL综合实例.
.ORACLE 错误信息报告程序.
.详细讲解Oracle数据库后台进程的.

ORACLE SQL性能优化系列(五)

发表日期:2005-12-23


7.     减少访问数据库的次数


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

例如,

    以下有三种方法可以检索出雇员号等于0342或0291的职员.


方法1 (最低效)


    SELECT EMP_NAME , SALARY , GRADE

    FROM EMP

    WHERE EMP_NO = 342;

    SELECT EMP_NAME , SALARY , GRADE

    FROM EMP

    WHERE EMP_NO = 291;


方法2 (次低效)


    DECLARE

        CURSOR C1 (E_NO NUMBER) IS

        SELECT EMP_NAME,SALARY,GRADE

        FROM EMP

        WHERE EMP_NO = E_NO;

    BEGIN

        OPEN C1(342);

        FETCH C1 INTO …,..,.. ;

        …..

        OPEN C1(291);

       FETCH C1 INTO …,..,.. ;

         CLOSE C1;

      END;

方法3 (高效)


    SELECT A.EMP_NAME , A.SALARY , A.GRADE,


            B.EMP_NAME , B.SALARY , B.GRADE


    FROM EMP A,EMP B


    WHERE A.EMP_NO = 342


    AND   B.EMP_NO = 291;


注意:


在SQL*Plus , SQL*Forms和Pro*C中重新设置ARRAYSIZE参数, 可以增加每次数据库访问的检索数据量 ,建议值为200

8.       使用DECODE函数来减少处理时间

使用DECODE函数可以避免重复扫描相同记录或重复连接相同的表.


例如:


   SELECT COUNT(*),SUM(SAL)

   FROM EMP

   WHERE DEPT_NO = 0020

   AND ENAME LIKE ‘SMITH%’;

   SELECT COUNT(*),SUM(SAL)

   FROM EMP

   WHERE DEPT_NO = 0030

   AND ENAME LIKE ‘SMITH%’;

你可以用DECODE函数高效地得到相同结果


SELECT COUNT(DECODE(DEPT_NO,0020,’X’,NULL)) D0020_COUNT,


        COUNT(DECODE(DEPT_NO,0030,’X’,NULL)) D0030_COUNT,

        SUM(DECODE(DEPT_NO,0020,SAL,NULL)) D0020_SAL,

        SUM(DECODE(DEPT_NO,0030,SAL,NULL)) D0030_SAL

FROM EMP WHERE ENAME LIKE ‘SMITH%’;


类似的,DECODE函数也可以运用于GROUP BY 和ORDER BY子句中.

上一篇:ORACLE SQL性能优化系列(四) 人气:8787
下一篇:ORACLE SQL性能优化系列(六) 人气:8905
浏览全部ORACLE SQL性能优化的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐