ITPub博客

首页 > Linux操作系统 > Linux操作系统 > oracle数据库优化(转)

oracle数据库优化(转)

原创 Linux操作系统 作者:jcszjswkzhou 时间:2019-06-19 19:03:04 0 删除 编辑
oracle数据库优化,sql,sql教程,Oracle基础

优化就是选择最有效的方法来执行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语句的执行效率不如第二句

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

这就节省了时间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 name||department=’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总是建立一个排序所以查询速度也慢

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/10294527/viewspace-122218/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论

注册时间:2007-08-29

  • 博文量
    3488
  • 访问量
    2621063