- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
DB2 Sql优化与锁 80%性能的提升在于Sql和索引的修改。总结有以下几点: 1、不合理的sql 2、如何建立合理的索引 3、避免死锁和大量锁等待 下面针对这3个方面总结下要点。 1.编写高效的Sql注意要点 表连接 表连接有两个要点: 1、表连接顺序,2、连接条件 Select * from A left join B on A.id=B.id join C on B.id = C.C_id where A.con=’ ’ and B.con=’ ’ 一般情况下,DB2会根据各表的JOIN顺序自顶向下处理,即从Sql来看,就是自左向右解析,先A、B做连接操作,之后会产生结果集,将会写入内存,如果内存不够,会写入临时表空间,之后会用结果集和C做连接操作。如果sql中只有两表连接,那么其前后顺序没什么关系,优化器会自己去评估。而如果sql中存在超过2个表连接时,那么表连接就会有顺序之分。那么,原则是: 如果sql中存在表A、B、C三表连接,则首先应保证最先连接的两表具有较小的子集。 在进行表连接时,需要提供连接字段(即On语法后的等价谓词,on A.id=B.id)。此时,我们需要保证,连接字段存在索引。这样当结果集小时,会走Nest Join(速度快,因为会利用到索引),当结果集大时,会走Hash join。此外,在对A、B表进行连接时,优化器需要判断采用何种连接类型,这时会先执行where 字句后的条件。也就是说,如果where字句能过滤很多的条件,那么表连接的结果集就会很小,cost自然会降低,所以适当为where字句的查询字段建立索引,能够得到更好的性能。原则是: 在进行表连接时,为连接字段和查询过滤字段(where 字句后的条件)建立索引,会得到很好的性能提升。 在本次测试中,发现有的sql会在表连接时,为其指定多个连接条件,形如: SELECT B.APPROVE_STATUS, count ( * ) AS NUM FROM BIZ.WF_TASK C LEFT JOIN BIZ.REI_FORM B ON C.RECEIPT_NO = B.REI_FORM_ID WHERE C.TASK_STATUS = 01 AND C.HANDLE_ID = 1234560000102 AND (C.RECEIPT_TYPE = 02 OR C.RECEIPT_TYPE = 03) GROUP BY B.APPROVE_STATUS WITH UR 执行cost: 如果sql写成(增加一个表连接字段): SELECT B.APPROVE_STATUS, count ( * ) AS NUM FROM BIZ.WF_TASK C LEFT JOIN BIZ.REI_FORM B ON C.RECEIPT_NO = B.REI_FORM_ID AND (C.RECEIPT_TYPE = 02 OR C.RECEIPT_TYPE = 03) WHERE C.TASK_STATUS = 01 AND C.HANDLE_ID = 1234560000102 GROUP BY B.APPROVE_STATUS WITH UR 对比结果,我们可以看到,当连接条件存在多个时,cost会高很多,因为多做了一次表连接。如果是小表,看不出差别,如果是大表关联,则结果很明显。原则是: 当进行表连接时,请确保连接条件只有一个,尤其是大表连接。 1.2 合理使用Not in 和Not Exists 虽然Not in 和Not exits 可以实现相同的功能,但是两者本身的实现方式不同: Not In:是自内向外操作,即先得到子查询结果,然后执行外层查询。包含not in 子句的执行顺序是:首先取外部一个查询结果与内部子集比较,不管是否存在,它都要遍历整个子集,往往无法利用到索引,因而是由内向外过程。所以,当内部查询子集很大时,就会具有较高的查询代价。 Not Exists:恰恰相反,是外向内操作。即先执行外部查询结果,然后再执行内部操作, 是集合操作。包含 not exists子句的执行顺序是:首先取外部一个查询结果与内部子集比较,若存在即刻返回,而不需要便利整个子集,如果存在索引,就会使用索引,因而是个自外而内的过程。所以,当内部子集很大时,相对来说,性能要优于Not in。 因而,总的来说,Not exits在整体性能上要由于Not in。原则是: 当子查询结果集较大时,Not exists 较 Not in 具有较高的性能提升; 当子查询结果集较小时(个数或者百数以内),两者相差不多,一般来说,此时Not in 会教优于Not exists。就好
您可能关注的文档
- 课外文体活动自查PPT.ppt
- 调车员作业指导书.doc
- 调车脱轨一般D类事故.ppt
- 厦门的台湾项目(二).pptx
- SIPOS电动执行器调试步骤及常见故障处理.ppt
- 原肠作用1.ppt
- 危险废物规范化管理(福州产废企业培训).ppt
- 谈健康危机.ppt
- 双学位全秀峰.docx
- 谈古论今话读书.ppt
- 高中手工编织课程对学生审美素养和审美能力培养的实践研究教学研究课题报告[001].docx
- 小学校园绿化带规划与生态环境建设研究教学研究课题报告.docx
- 《农业废弃物堆肥化处理技术对土壤有机碳储量与土壤酶活性的影响研究》教学研究课题报告.docx
- 高考法律逻辑大题题库及答案.doc
- 初中生网络学习平台学习策略与学习成果的关系探讨教学研究课题报告.docx
- 《电影院口碑传播营销策略对观众观影频率的提升作用研究》教学研究课题报告.docx
- 教学方法导论题库及答案.doc
- 小学面试试讲真题库及答案.doc
- 初中物理教学中数字化组织文化建设与教学效果分析教学研究课题报告.docx
- 人工智能在高中物理个性化学习中的应用:激发与维持学习兴趣的策略探讨教学研究课题报告.docx
最近下载
- 企业数字化转型大数据湖一体化运营管理平台建设方案.docx VIP
- 《活着读后感》课件.pptx VIP
- 活着读后感课件.docx VIP
- 企业大数据湖总体规划及大数据湖一体化运营管理建设方案.pdf VIP
- 鄂尔多斯市东胜区殡仪馆项目环境影响报告表环评报告.pdf
- 社会研究:设计与写作教学课件-第十二章 实例解析.pptx VIP
- 社会研究:设计与写作教学课件-第十一章 论文写作(下):结果、讨论、参考文献.pptx VIP
- 社会研究:设计与写作教学课件-第十章 论文写作(中):文献回顾、研究方法.pptx VIP
- 腾讯云原生湖仓一体技术在大规模数据场景中的应用实践.pdf VIP
- 腾讯数据湖技术分享专场.docx VIP
文档评论(0)