动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
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教程 ]的信息

本月文章推荐
.分享:我的oracle9i学习笔记(二).
.用最简单的方法复制或迁移Oracle.
.Oracle 9i新特性研究系列之四 --.
.在ORACLE里设置访问多个SQL Serv.
.Linux 平台上之 Multipath Routi.
.oracle 学习笔记之一.
.Oracle压力测试之orabm.
.Oracle数据库游标使用大全(1).
.Oracle中的外连接简单介绍.
.Oracle数据库安全策略分析(二).
.Oracle 细料度审计.
.Oracle9i RAC Archivelog方式修改.
.Oracle Lite 10g数据库第三版正式.
.[转贴]如何正确利用Rownum来限制.
.vsftpd-1.1.3配制实例之五:VIRT.
.日常监测分析数据库的DBA_Monito.
.ORACLE在HP-UX下的系列问题处理(.
.讨论:数据库管理员职责.
.Oracle 分析函数的使用一.
.ExactPapers Oracle 1Z0-301 200.

oracle数据库优化

发表日期:2008-2-9 |



  
优化就是选择最有效的方法来执行SQL语句。Oracle优化器选择它认为最有效的

方法来执行SQL语句。

 

1).      IS NULL和IS NOT NULL

假如某列存在NULL值,即使对该列建立索引也不会提高性能。

2).      为不同的工作编写不同的SQL语句块

为完成不同的工作编写一大块SQL程序不是好方法。它往往导致每个任务的结果不优

化。若要SQL完成不同的工作,一般应编写不同的语句块比编写一个要好。

3).      IN 和EXISTS

Select name from employee where name not in (select name from student);

Select name from employee where not exists (select name from student);

第一句SQL语句的执行效率不如第二句。

通过使用EXISTS,Oracle会首先检查主查询,然后运行子查询直到它找到第一个匹配

项,这就节省了时间。Oracle在执行IN子查询时,首先执行子查询,并将获得的结果

列表存放在一个加了索引的临时表中。在执行子查询之前,系统先将主查询挂起,待

子查询执行完毕,存放在临时表中以后再执行主查询。这也就是使用EXISTS比使用IN

通常查询速度快的原因。

4).      NOT 运算符

Select * from employee where salary<>1000;

Select * from employee where salary<1000 or salary>1000;

第一句SQL语句的执行效率不如第二句,因为第二句SQL语句可以使用索引。

5).      Order By 语句

Order By 语句的执行效率很低,因为它要排序。应避免在Order By 字句中使用表达式。

6).      列的连接

select * from employee where namedepartment=’ZYZBIOINFO’;

select * from employee where name=’ZYZ’ and department=’BIOINFO’;

这两个查询,第二句比第一句会快,因为对于有连接运算符’’的查询,Oracle优化器是不

会使用索引的。

7).      通配符‘%’当通配符出现在搜索词首时,Oracle优化器不使用索引

Select * from employee where name like ‘%Z%’;

Select * from employee where name like ‘Z%’;

第二句的执行效率会比第一句快,但查询结果集可能会不同。

8).      应尽量避免混合类型的表达式

假设字段studentno为VARCHAR2类型

有语句select * from student where studentno>123;

则Oracle会有一个隐含的类型转换。隐含的类型转换可能会使Oracle优化器忽略索引。

这时应使用显式的类型转换select * from student where studentno=to_char(123)。

9).DISTINCT
   DISTINCT总是建立一个排序,所以查询速度也慢。
上一篇:Oracle里的交叉SQL语句写法 人气:532
下一篇:Oracle_Chapter 1 人气:452
浏览全部Oracle教程的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-10-14 25175学生成绩管理系统 v2.88
2008-10-14 冰雪CMS v2.0 bulid 081013
2008-10-14 Modoer多功能点评系统 v1.1 Beta
2008-10-14 乐风CMS乐风影视版 v2008.10.13
2008-10-14 FeitecCMS 40T免费资源网整站源码
2008-10-14 Asoft签到管理系统 v3.0 Pack2
2008-10-14 金博人才招聘求职网黄金版 v4.2
2008-10-14 游戏推广无限制版本
2008-10-14 AmEav WebSite 业网站管理系统 英
2008-10-11 联系人分组工具 v1.1 中文破解版
2008-10-11 FaceMelter变脸 v2.0 汉化破解版
2008-10-11 PathTracker道路跟踪仪 v1.2 破解
2008-10-11 Rooms手机聊天室 v0.6.7 破解版
2008-10-11 RemoteDesktop远程桌面 v1.0 破解
2008-10-11 ProRemote远程调音台 v1.0.1 破解
2008-10-11 PicShare照片共享 v1.0.0 破解版
2008-10-11 Photogene照片编辑器 v1.5 汉化破
2008-10-11 WriteRoom共享文档 v1.0 破解版
  发表评论
姓 名: 验证码:
内 容:
站长工具:网站收录查询 | Google PR查询 | ALEXA排名查询 | CSS在线编辑器 | 广告代码 | js/vbs加密 | md5加密 | 进制转换 | UTF-8 转换工具 | Html转换js | Html转换asp | Html转换php | Html转换perl
实用工具:汉字翻译拼音 | 拼音字典 | 符号对照表 | 个税计算 | 实时汇率查询换算 | 经典小工具 | 汉字简繁转换 | 普通单位换算 | 公制单位换算 | 生辰老黄历 | 国内电话区号 | 国家代码与域名缩写 | 文字加密解密 | 健康查询 | 万年历 | 汉字横竖排版 | 手机号码查询 | 计算器 | ip搜索
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号
ホームページ制作 不動産検索システム 求人情報
防水工事·改修工事 フットサル大会 探偵
SEO対策 中国語教室 ホームページ作成