32. 使用提示(Hints)
- FULL hint 告诉ORACLE使用全表扫描的方式访问指定表。
- ROWID hint 告诉ORACLE使用TABLE ACCESS BY ROWID的操作访问表。
- CACHE hint 来告诉优化器把查询结果数据保留在SGA中。
- INDEX Hint 告诉ORACLE使用基于索引的扫描方式。
其他的Oracle Hints
- ALL_ROWS
- FIRST_ROWS
- RULE
- USE_NL
- USE_MERGE
- USE_HASH 等等。
这是一个很有技巧性的工作。建议只针对特定的,少数的SQL进行hint的优化。
33. 几种不能使用索引的WHERE子句
(1)下面的例子中,‘!=’ 将不使用索引 ,索引只能告诉你什么存在于表中,而不能告诉你什么不存在于表中。
(2)下面的例子中,‘||’是字符连接函数。就象其他函数那样,停用了索引。
(3)下面的例子中,‘+’是数学函数。就象其他数学函数那样,停用了索引。
(4)下面的例子中,相同的索引列不能互相比较,这将会启用全表扫描。
34. 连接多个扫描
如果对一个列和一组有限的值进行比较,优化器可能执行多次扫描并对结果进行合并连接。
举例:
优化器可能将它转换成以下形式:
35. CBO下使用更具选择性的索引
- 基于成本的优化器(CBO,Cost-Based Optimizer)对索引的选择性进行判断来决定索引的使用是否能提高效率。
- 如果检索数据量超过30%的表中记录数,使用索引将没有显著的效率提高。
- 在特定情况下,使用索引也许会比全表扫描慢。而通常情况下,使用索引比全表扫描要块几倍乃至几千倍!
36. 避免使用耗费资源的操作
- 带有DISTINCT,UNION,MINUS,INTERSECT,ORDER BY的SQL语句会启动SQL引擎执行耗费资源的排序(SORT)功能。DISTINCT需要一次排序操作,而其他的至少需要执行两次排序。
- 通常,带有UNION,MINUS,INTERSECT的SQL语句都可以用其他方式重写。
37. 优化GROUP BY
提高GROUP BY语句的效率,可以通过将不需要的记录在GROUP BY之前过滤掉。
38. 使用日期
当使用日期时,需要注意如果有超过5位小数加到日期上,这个日期会进到下一天!
39. 使用显示游标(CURSORS)
使用隐式的游标,将会执行两次操作。第一次检索记录,第二次检查TOO MANY ROWS 这个exception。而显式游标不执行第二次操作。
40. 分离表和索引
- 总是将你的表和索引建立在不同的表空间内(TABLESPACES)。
- 决不要将不属于ORACLE内部系统的对象存放到SYSTEM表空间里。
- 确保数据表空间和索引表空间置于不同的硬盘上。
好了,关于Oracle SQL优化的内容,这一篇应该满足常规大部分的应用优化要求。就先到这里了。