SQL语句优化-重点在于使用到索引

一:减少数据库中的null值

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

 

二:注意NOT 运算符

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

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

 

三:列的连接

select * from employee where name||department=’ICEDEVELOP’;
select * from employee where name=’ICE’ and department=’DEVELOP’;

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

 

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

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

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

 

五:尽量避免混合类型的表达式

假设字段salary为varchar2类型,有语句select * from student where salary>10000;

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

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

 

六:为不同的工作编写不同的SQL语句块

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

一般应编写不同的语句块比编写一个要好。尽量不写过于复杂的sql,简单是效率的前提,稳定的前提。

 

七:  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会优先检查主查询,然后运行子查询直到它找到第一个匹配项。

执行IN子查询时,首先执行子查询,并将获得的结果列表存放在一个加了索引的临时表中。在执行子查询之前,系统先将主查询挂起,

待子查询执行完毕,存放在临时表中以后再执行主查询。

 

八: Order By 语句

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

 

九:DISTINCT

DISTINCT总是建立一个排序,所以查询速度也慢。


 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值