WEB开发网
开发学院数据库Oracle 教你从应用程序来优化Oracle数据库 阅读

教你从应用程序来优化Oracle数据库

 2007-05-06 12:05:59 来源:WEB开发网   
核心提示: select * from employee where first_name||''||last_name ='George Bush';上面这条语句完全可以查询出是否有George Bush这个员工,但是这里需要注意,教你从应用程序来优化Oracle数据
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语句:

select * from employee where last_name like '%Bush%';

这里由于通配符(%)在搜寻词首出现,所以Oracle系统不使用last_name的索引。在很多情况下可能无法避免这种情况,但是一定要心中有底,通配符如此使用会降低查询速度。然而当通配符出现在字符串其他位置时,优化器就能利用索引。例如,在下面的查询中索引得到了使用:

select * from employee where last_name like 'c%';

4.Order by语句

上一页  1 2 3 4  下一页

Tags:应用程序 优化 Oracle

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