当前位置:七道奇文章资讯数据防范MSSQL防范
日期:2011-05-02 15:22:00  来源:本站整理

sql优化器探究[MSSQL防范]

赞助商链接



  本文“sql优化器探究[MSSQL防范]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
多年以来,商业数据库生产商一向努力于提高数据库的查询性能.固然他们持续地付出勤奋和勤劳地工作,我们还是无法看到关系型数据库系统(rdbms)在性能上有明显的提高.用户持续忍耐性能低下的sql语句,数据库专家们持续在sql语句优化的泥潭中痛楚挣扎.?

  本文将介绍数据库查询优化器是若何工作的、为什么问题持续存在,并深化探究数据库查询优化器将来的发展方向.?

  数据库查询优化器?

  数据库查询优化器是rdbms服务器的一个构成部份.关于基于本钱的优化,数据库查询优化器的任务是,通过产生可供挑选的履行筹划,找到最低预算本钱的履行筹划,来优化一条sql语句.它在sql语句性能表现上扮演了至关重要的角色.?

  当一条sql语句被送入rdbms服务器,它将会被解析并提交给数据库查询优化器.查询优化器将会举行查询重写和表达式评价,以产生可供挑选的履行筹划.产生可供挑选的履行筹划的数目,取决于在rdbms中定义的筹划空间(plan?space)大小.关于每个待选的履行筹划,本钱预计将被计算,带有最小本钱的履行筹划将被选取用来履行sql语句.这种办法存在着两个无法办理的问题:无法产生全部大概的可选履行筹划和本钱预计的不精确.?

  新的sql优化概念——外部sql重写器?

  一个有经验的程序员,把有问题的sql语句的速度提高数千倍是很常见的.凭着对具体数据库特点的理解,对sql语句举行语法的重新构造.一个开辟人员可以帮忙查询优化器得到更好的履行筹划,而这履行筹划是查询优化器无法靠自身独立工作产生的.这赐与我们一个启迪,我们能否能通过计算机模拟人的行为,来实现一样的目的呢??

显示了外部sql重写器(external?sql?rewriter--esr)的概念,它可以基于现有数据库的特点,产生语义相等但语法差别的sql语句.重写产生的sql语句,将代替程序源代码中的源sql语句.这样,当程序运行时(利用新的sql语句),查询优化器将会被影响,而产生性能更好的履行筹划.事实上,有经验的程序员和数据库管理员,一向在期盼着这个概念的呈现.这个概念的新颖之处在于,将人类的知识和智能归并到一个计算机算法中,它可以冲破筹划空间(plan?space)限制的障碍,避免在探求最佳sql语句时不精确的本钱预算.?

  esr的长处是,它的优化并非一个基于及时,可用于重写和优化sql语句的时间,在理论上是无限的.它可以比数据库的查询优化器尝试更多的待选sql语句.用户耗费多达一天的时间来处理关键sql语句的性能问题,而esr可以完好探求大概的待选履行筹划.esr的别的一个长处是,可以到达sql性能提高的目的,而无需举行额外的统计,使数据库查询优化器的负载太重.因此,esr使得晋升整个数据库性能变得简单且安全.最后,esr相关于数据库内部的查询优化器越发机动:sql重写的知识库可以很简单扩大,搜索空间可以通过硬件的进级来扩大,而毫无限制和缺陷.?

  esr是若何工作的??

  为了让esr可以优化sql语句,必须避免数据库内部查询优化器限制所产生的障碍.别的,esr必须拥有重写sql语句的智能,并知道你数据库的特点,来供应待选的sql语句.固然到达上面的要求是艰难的,但是开辟一个这样的算法也不是不大概的.国内市场上已经过盈动华建公司代理推出了一个相当作熟的产品——lecco?technology?的lecco?sql?expert.?

  sql语句可以被直接输入,或通过查抄源代码来捕捉有问题的sql语句.当esr收到sql语句,一个递归的转换算法被利用来重写源sql语句,产生每一个大概的语义等价的待选sql语句.递归的sql转换引擎,拥有内建的人工智能和sql转换法则,它按照具体数据库的特点来重新构造sql语句.?

  可扩大的筹划空间?

  用户可自定义的限额让用户可以掌握搜索空间.假如用户对在定义的限额内产生的后果不称心,或无法找到性能更好的待选sql语句,用户可以提高限额来增添搜索空间,直到更多的待选sql语句被找到.因此,esr的筹划空间的扩大,要比数据库查询优化器有弹性得多.另一个考虑周到的特点是,esr可以在内部把具有反复履行筹划的sql语句给排撤除.这样不但削减了人工反复尝试的本钱,还保证了重写产生的每条sql语句,都具有差别的履行筹划和性能.?

固然esr可以扩大它的筹划空间和产生更多的待选sql语句,它还是和数据库内部查询优化器一样,面对着不精确的本钱预算的问题.没有实际地履行过每一条重写后的sql语句,是根本无法知道,在全部待选sql语句中到底哪一条的性能最好.因此,实际的途径是,测试运行全部的待选sql语句.图2中的esr例子利用了这一办法并附加供应了测试选项来找到性能最好的sql语句.用户可以挑选,什么时刻来开始测试和答应举行多长时间的测试.此外,esr的重要性还在于,整个优化历程不需求利用者具有数据库专家的经验.正如我们所知道的,差别的sql语法可以惹起数据库查询优化器产生差别的履行筹划,因此esr也必须具有模拟人工重写sql语句的本领.递归式sql语法转换技术,恰是用来模拟人的sql转换办法.它归并一系列有效的转换法则,并利用一次触发一条的办法来转换sql语句.全部的转换法则是不彼此依靠的,就像一个个密封的小门,只有在全部必须的条件都满意的情形下,某个密封门才会被翻开.这保证了重写后的sql语句与原sql语句在语义上是等效的.?

  esr技术的展望?

  随着硬件的进级,esr可以归并更多的sql转换法则,来处理数据库的新特点和更复杂的sql语句,理论上,法则的数目是没有限制的.将来,随着数据库生产商在让用户影响数据库优化器方面越发开放,esr将会在优化战略方面得到更多的掌握.毫无疑问,esr将会在分担数据库查询优化器的工作负荷上,扮演越来越重要的角色
  以上是“sql优化器探究[MSSQL防范]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • MySQL优化简明指南
  • sql优化器探究
  • my.ini(my.cnf)与mysql优化指南
  • MySQL优化 之 Discuz论坛优化
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .