预览加载中,请您耐心等待几秒...
1/10
2/10
3/10
4/10
5/10
6/10
7/10
8/10
9/10
10/10

亲,该文档总共174页,到这已经超出免费预览范围,如果喜欢就直接下载吧~

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

ORACLE培训--SQL性能优化内容概述目录一、优化基础知识概述性能管理SQL优化衡量指标调优领域调整的方法不同调整产生相应性能收益调整的角色SQL语句优化是提高性能的重要环节SQL语句优化的过程什么是好的SQL语句?SQL共享原理SQL共享原理SQL共享的三个条件共享SQL语句SQL语句的处理过程Sql处理过程SQLPARSE与共享SQL语句为什么要bindvariables?什么叫做重编译问题绑定变量解决重编译问题绑定变量的注意事项SQL语句的四个处理阶段解析(PARSE):绑定(BIND):执行(EXECUTE):共享游标:好处书写可共享的SQL绑定变量和共享游标ORACLE优化器模式概述访问数据表的方式数据库性能SQLTunning的重点SQL优化的一般性原则优化概括优化概括**SQLTunningTips**sql语句的编写原则和优化sql语句的编写原则和优化TunningTip的各个方面1.不要让Oracle做得太多避免复杂的多表关联避免使用‘*‘避免使用耗费资源的操作用EXISTS替换DISTINCT用UNION-ALL替换UNION(ifpossible)2.给优化器更明确的命令自动选择索引至少要包含组合索引的第一列避免在索引列上使用函数避免使用前置通配符避免在索引列上使用NOT避免在索引列上使用ISNULL和ISNOTNULL避免出现索引列自动转换在查询时尽量少用格式转换3.减少访问次数减少访问数据库的次数使用DECODE来减少处理时间减少对表的查询4.细节上的影响WHERE子句中的连接顺序WHERE子句——函数、表达式使用Orderby语句联接列带通配符(%)的like语句用Where子句替换HAVING子句用NOTEXISTS替代NOTIN用索引提高效率避免在索引列上使用计算用>=替代>通过使用>=、<=等,避免使用NOT命令如果有其它办法,不要使用子查询。外部联接"+"的用法尽量多使用COMMIT用TRUNCATE替代DELETE计算记录条数字符型字段的引号优化EXPORT和IMPORT**优化Tools**SQL语句的执行步骤优化器与执行计划优化器与执行计划用EXPLAINPLAN分析SQL语句Autotrace解读使用TKPROF工具在SQLPLUS配置AUTOTRACE在SQLPLUS配置AUTOTRACE优化器与执行计划目录性能调整综述谁来调整系统谁来调整系统谁来调整系统什么时候调整系统什么时候调整系统什么时候调整系统调整的目标调整的目标SQL调整的目标在设计和开发时调整在设计和开发时调整目录有效的应用设计有效的应用设计目录SQL语句的处理过程SQL语句执行过程DML语句的处理DML语句的处理以上语句处理步骤解释以上语句处理步骤解释以上语句处理步骤解释查询语句的处理查询语句的处理查询语句的处理查询语句的处理DDL语句的处理事务控制目录Oracle优化器基于规则的优化器--RuleBased(Heuristic)Optimization(简称RBO)基于规则的优化器--RuleBased(Heuristic)Optimization(简称RBO)基于代价的优化器--CostBasedOptimization(简称CBO)判断当前数据库使用何种优化器目录内容提纲优化定义内容提纲概念分析概念分析概念分析概念分析概念分析概念分析概念分析概念分析概念分析内容提纲执行计划分析执行计划分析执行计划分析执行计划的步骤实现执行计划步骤的顺序内容提纲优化器选择内容提纲访问路径(方法)--accesspath全表扫描通过ROWID的表存取(TableAccessbyROWID或rowidlookup)索引扫描(IndexScan或indexlookup)根据索引的类型与where限制条件的不同,有4种类型的索引扫描: 索引唯一扫描(indexuniquescan) 索引范围扫描(indexrangescan) 索引全扫描(indexfullscan) 索引快速扫描(indexfastfullscan)索引唯一扫描(indexuniquescan) 通过唯一索引查找一个数值经常返回单个ROWID。如果该唯一索引有多个列组成(即组合索引),则至少要有组合索引的引导列参与到该查询中,如创建一个索引:createindexidx_testonemp(ename,deptno,loc)。则selectenamefromempwhereename=‘JACK’anddeptno=‘DEV’语句可以使用该索引。如果该语句只返回一行,则存取方法称为索引唯一扫描。而selectenamefromempwheredeptno=‘DEV’语句则不会使用该索引,因为where子句种没有引导列。如果存在UNIQUE或PRIMARYKEY约束