1 序言 2 2 影响SQL PERFORMANCE的关键因素和配置: 2 2.1 关于执行计划 2 2.2 ORACLE优化器 2 2.2.1 ORACLE优化器的优化方式 2 2.2.2 优化器的优化模式(Optermizer Mode) 3 2.2.3 Optimizer mode优化模式级别的设定: 3 2.2.4 查看对象统计信息(object statistics) 3 2.3 结合BENQ ORACLE ERP 4 2.3.1 优化模式(Optermizer Mode) 4 2.3.2 关于 Gather 5 2.4 跟踪 SQL实际运行的COST 5 2.5 小结 5 3 SQL语句的TUNING经验分享: 6 3.1 绝大多数情况下NOT EXISTS比NOT IN 效率高 6 3.2 UNION ALL效率比UNION高很多 6 3.3 一些很耗资源的SQL操作,在不必要的情况下不要使用 6 3.4 通常联接查询比子查询的效率要高很多 7 3.5 用TABLE 索引(INDEX)栏位去做TABLE间的关联,可避免费时的全表扫描 7 3.6 在VIEW中尽量不要使用 PACKAGE/FUNCTION 来得到栏位值, 8 3.7 通过R OWID访问表 9 3.8 必要时,可在ORACLE STANDARD TABLE上加索引 9 3.9 合理排列WHERE子句中的连接顺序. 9 3.10 用WHERE子句替换HAVING子句 9 3.11 关于使用索引(INDEX)的一些注意点 10 3.11.1 ‘!=’,NOT操作将不使用索引. 10 3.11.2 ‘||’是字符连接函数. 就象其它函数那样, 停用了索引. 10 3.11.3 相同的索引列不能互相比较,这将会启用全表扫描. 10 3.11.4 避免在索引列上使用计算. 11 3.11.5 基于成本的优化器(CBO)会对索引的选择性进行判断,来决定是否使用索引 11 3.11.6 Index信息的重新统计 11 3.12 识别 “低效运行”的SQL语句 11 OWID访问表 9 3.8 必要时,可在ORACLE STANDARD TABLE上加索引 9 3.9 合理排列WHERE子句中的连接顺序. 9 3.10 用WHERE子句替换HAVING子句 9 3.11 关于使用索引(INDEX)的一些注意点 10 3.11.1 ‘!=’,NOT操作将不使用索引. 10 3.11.2 ‘||’是字符连接函数. 就象其它函数那样, 停用了索引. 10 3.11.3 相同的索引列不能互相比较,这将会启用全表扫描. 10 3.11.4 避免在索引列上使用计算. 11 3.11.5 基于成本的优化器(CBO)会对索引的选择性进行判断,来决定是否使用索引 11 3.11.6 Index信息的重新统计 11 3.12 识别 “低效运行”的SQL语句 11