Oracle中建立索引并强制优化器使用
WHERE replace(replace(replace(replace
(phone_number , ' - ' ) ,' '),'( ' )
, ' ) ' ) = '1234567890' AND
(phone number like ' 123% '
or phone_number like ' (123% ' ) '
该例强调了巧妙地选用WHERE 子句条件的重要性,而且,这些条件不会改变查询结果。你的选择应基于完全了解该列中存在的信息类型。在该例中,我们需要知道 PHONE_NUMBER 数据中存在几种不同的格式,这样,我们能够修改WHERE 子句而不会影响查询结果。
正确的条件
以后当你遇到包含CHARACTER 数据修改函数列的WHERE 子句时,应考虑怎样利用增加一个或两个特定的条件,迫使优化器使用索引。适当地选择一组特定的条件能减少扫描行,并且强制使用索引不会影响查询结果----但却提高了查询的执行速度。
上一篇:Oracle数据库及应用程序优化
下一篇:调整Oracle应用系统性能的原则和方法
关注此文读者还看过



