WEB开发网
开发学院数据库Oracle Oracle数据库的系统性能优化策略浅析 阅读

Oracle数据库的系统性能优化策略浅析

 2007-05-10 12:20:55 来源:WEB开发网   
核心提示: 任何在where子句中使用is null或is not null的语句优化器是不允许使用索引的,2. 联接列对于有联接的列,Oracle数据库的系统性能优化策略浅析(3),即使最后的联接值为一个静态值,优化器不会使用索引的,下面是SQL查询脚本:select * from employee

任何在where子句中使用is null或is not null的语句优化器是不允许使用索引的。

2. 联接列

对于有联接的列,即使最后的联接值为一个静态值,优化器不会使用索引的。例如,假定有一个职工表(employee),对于一个职工的姓和名分成两列存放(FIRST_NAME和LAST_NAME),现在要查询一个叫乔治·布什(George Bush)的职工。 下面是一个采用联接查询的SQL语句:

select * from employee where first_name||''||last_name ='George Bush';

上面这条语句完全可以查询出是否有George Bush这个员工,但是这里需要注意,系统优化器对基于last_name创建的索引没有使用。

当采用下面这种SQL语句的编写,Oracle系统就可以采用基于last_name创建的索引:

Select * From employee where first_name ='George' and last_name ='Bush';

遇到下面这种情况又如何处理呢?如果一个变量(name)中存放着George Bush这个员工的姓名,对于这种情况我们又如何避免全程遍历使用索引呢?可以使用一个函数,将变量name中的姓和名分开就可以了,但是有一点需要注意,这个函数是不能作用在索引列上。下面是SQL查询脚本:

select * from employee where first_name = SUBSTR('&&name',1,INSTR('&&name',' ')-1)
and last_name = SUBSTR('&&name',INSTR('&&name’,' ')+1) ;

3. 带通配符(%)的like语句

同样以上面的例子来看这种情况。目前的需求是这样的,要求在职工表中查询名字中包含Bush的人。可以采用如下的查询SQL语句:

上一页  1 2 3 4 5  下一页

Tags:Oracle 数据库

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接