avh新一代智能SQL语句优化技术课件.ppt
- 【下载声明】
1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
3. 本页资料《avh新一代智能SQL语句优化技术课件.ppt》由用户(晟晟文业)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- avh 新一代 智能 SQL 语句 优化 技术 课件
- 资源描述:
-
1、Where the experts go for performance杜伟业杜伟业(Richard To)Richard To)RichardtoRichardto 技术总监技术总监 灵高科研有限公司灵高科研有限公司Where the experts go for performance什么是反应时间1/101/10秒是用户认为系统能够立即反应的极限秒是用户认为系统能够立即反应的极限1 1 秒是用户觉得没有被中断的极限秒是用户觉得没有被中断的极限1010秒秒是用户能将注意力继续集中在与计算机的对是用户能将注意力继续集中在与计算机的对话上的时间极限话上的时间极限引用自Jakob Nielsen
2、 的“Usability Engineering”第五章(Morgan Kaufmann,San Francisco出版)Where the experts go for performance我们可以关注的地方可调整的部分:硬件操作系统数据库网络应用程序许多人在试图提高数据库应用程序性能时只将注意力放在了前三项:硬件、操作系统、数据库Where the experts go for performance数据库系统各部分对性能的影响应用程序应用程序数据库数据库操作系统操作系统硬件硬件网络网络Where the experts go for performance40%60%应用程序应用程序其
3、它最 少 60%的 数 据 库 性 能 问 题 是 由 应 用 程 序 引 起 的 性能的挑战Where the experts go for performance我们可以优化什么?数据库设计问题数据库设计问题编程问题编程问题索引问题索引问题SQLSQL问题问题Where the experts go for performance什么是 SQL?(结构化查询语言)F访问和更新数据F对应用程序的性能产生最重大的影响FSQL语句消耗70%到90%的数据库系统资源FSQL语句可以有多种写法F易学,但难以精通F需要考虑在数据和系统环境变化后仍能达到最佳化Where the experts go f
4、or performance服务器收到SQL语句SQL语句解析数据库的优化器决定执行路径数据库的优化器决定执行路径变量赋值执行数据库是如何处理SQL语句的?Where the experts go for performanceSQL数据库的优化器是如何工作的?内部重写并产生多种执行计划执行计划1执行计划2执行计划3成本估计执行计划1 成本=1000执行计划2 成本=3000执行计划3 成本=500执行它是否尝试了所有的的途径来重写你的SQL语句?成本的估计有多精确?Where the experts go for performance优化器说明什么是执行计划SQL语法如何影响优化器的决定W
5、here the experts go for performance什么是SQL优化?Where the experts go for performance解决这个问题的传统解决这个问题的传统途径途径Where the experts go for performance执行计划SET SHOWPLAN ONGOSELECT*FROM EMPLOYEE WHERE EMP_ID 73712GOSET SHOWPLAN OFFGOQUERY PLAN FOR STATEMENT 1(at line 1).STEP 1 The type of query is SELECT.FROM TABL
6、E EMPLOYEE Nested iteration.Table Scan.Forward scan.Positioning at start of table.Using I/O Size 2 Kbytes for data pages.With LRU Buffer Replacement Strategy for data pages.Total estimated I/O cost for statement 1(at line 1):20600.iSQLWhere the experts go for performanceIO和时间统计信息SET STATISTICS IO ON
7、GOSET STATISTICS TIME ONGOSELECT*FROM EMPLOYEE WHERE EMP_ID 73712GOSET STATISTICS IO OFFGOSET STATISTICS TIME OFFGOiSQLServer Message:Number 3631,Severity 10Line 1:Total actual I/O cost for this command:0.Total writes for this command:0 Server Message:Number 3631,Severity 10Line 1:Total actual I/O c
8、ost for this command:0.Total writes for this command:0 Execution Time 0.SQL Server cpu time:0 ms.SQL Server elapsed time:3614 ms.Parse and Compile Time 0.SQL Server cpu time:0 ms.Table:EMPLOYEE scan count 1,logical reads:(regular=1030 apf=0 total=1030),physical reads:(regular=0 apf=0 total=0),apf IO
9、s used=0 Server Message:Number 3631,Severity 10Line 1:Total actual I/O cost for this command:2060.Total writes for this command:0 Execution Time 16.SQL Server cpu time:1600 ms.SQL Server elapsed time:7730 ms.(18371 rows affected)Parse and Compile Time 0.SQL Server cpu time:0 ms.Execution Time 0.SQL
10、Server cpu time:0 ms.SQL Server elapsed time:0 ms.Parse and Compile Time 0.SQL Server cpu time:0 Where the experts go for performanceTraceonDBCC TRACEON(3604,302,310)GOSELECT*FROM EMPLOYEE WHERE EMP_ID 73712GOiSQLBeginning selection of qualifying indexes for table EMPLOYEE,varno=0,objectid 159382479
11、0.The table(Allpages)has 18373 rows,1030 pages,Data Page Cluster Ratio 0.998890Table scan cost is 18373 rows,1030 pages,using no data prefetch(size 2K I/O),in data cache default data cache(cacheid 0)with LRU replacementSelecting best index for the SEARCH CLAUSE:EMPLOYEE.EMP_ID 73712.000000Estimated
12、selectivity for EMP_ID,selectivity=0.999946.Estimating selectivity of index EMPLOYEE_1961957491,indid 1 scan selectivity 0.999946,filter selectivity 0.999946 18372 rows,1032 pages,index height 2,Data Row Cluster Ratio 1.000000,Index Page Cluster Ratio 0.000000,Data Page Cluster Ratio Where the exper
13、ts go for performance使用 EXIST 还是 IN?SELECT*FROM A WHERE A.CITY IN(SELECT B.CITY FROM B)SELECT*FROM A WHERE EXISTS(SELECT X FROM B WHERE B.CITY=A.CITY)EXIST or INEXIST or INWhere the experts go for performance表连接与子查询通情况下表连接(Table join)要好过子查询(sub-query)源语句源语句 SELECT*FROM A WHERE A.CITY IN(SELECT B.CIT
14、Y FROM B)重写后重写后SELECT A.*FROM A,B WHERE A.CITY=B.CITY /*if B.CITY is unique in B*/Where the experts go for performance如果你确实知道问题所在,可以强制使用一个特殊的表操纵路径(driving path)。源语句源语句SELECT*FROM A,B WHERE A.STATE=B.STATE重写后的语句重写后的语句/*禁止使用B的索引来改变表操纵路径(B drive A)*/SELECT*FROM A,B WHERE A.STATE=ISNULL(B.STATE,B.STATE)
15、Joins Change Table Driving PWhere the experts go for performance要使用索引就不能在该索引字段上进行操作要使用索引就不能在该索引字段上进行操作源语句源语句/*A.key1上的索引被使用上的索引被使用*/SELECT*FROM A WHERE A.Key1=ver1 AND A.Key2=ver2重写后重写后/*禁止使用字段禁止使用字段A.key1上的索引,使用字段上的索引,使用字段A.Key2上的索引上的索引*/SELECT*FROM A WHERE ISNULL(A.Key1,A.key1)=ver1 AND A.Key2=ver
16、2 Use IndexesUse IWhere the experts go for performance学习使用强制选项学习使用强制选项(Forces Options)SET FORCEPLAN ONINDEX hintPARALLEL hintSET SORT_MERGE ONSET JTC ONSET TABLE COUNTForcesFWhere the experts go for performance使用FORCEPLAN 强制选项强制使用特殊的表操纵路径(driving path)。原来的方法原来的方法 /*禁止使用B的索引来改变表操纵路径(B drive A)*/SELEC
17、T*FROM A,B WHERE A.STATE=ISNULL(B.STATE,B.STATE)用用 FORCEPLAN重写后重写后SET FORCEPLAN ONGOSELECT*FROM B,A WHERE A.STATE=B.STATEGOJoins Change Table Driving PWhere the experts go for performance强制索引(Force Index)SELECT*FROM EMPLOYEE WHERE EMP_ID 73712Force Index备注:仅在事先知道使用使用索引 x 将会较快的情况下采用(INDEX EMP_ID_INX)
展开阅读全文