zoukankan      html  css  js  c++  java
  • SQL Server ->> 性能调优案例之 -- 包含递归查询的视图导致整个查询语句性能下降

    有个语句最近性能下降很厉害,原本1秒就可以查询完毕的事情现在居然需要3-4分钟。

    首先我的做法是先快速找出导致整个语句下降的元凶。在这个例子里面查询语句有3个JOIN字句,我通过删除某一个JOIN节点来观察执行时间是否出现本质的变化,这样我就找到了原来是包含了递归查询的视图导致了整个查询语句性能的下降严重。然后我运行了一遍查询语句获取真实的执行计划(图形)。通过执行计划我观察到属于递归查询的那一部分执行计划的节点每次都会输出非常大量的数据流,比如一个聚集索引扫描操作符输出的数据行数是真实表内数据行数数量的上百倍至少,对比这个视图单独执行是截然不同的结果。我的想法是为什么SQL SERVER笨到去选择这样的执行计划呢。显然这个包含递归查询的视图是最后一个JOIN字句。如果前面的JOIN字句都先完成后再进行最后一个JOIN,这样问题不就解决了。那么我尝试把视图单独拿出来,而前面的JOIN编程一个子查询(衍生表/独立子查询)再和包含递归查询的视图做JOIN。结果执行计划彻底改变。这个应该是一个典型的执行先后顺序导致性能下降的例子。解决方法是尝试隔离导致问题的视图,等其他的工作都完成后再和这个视图进行连接,观察变化。

    SQL SERVER版本是 Microsoft SQL Server 2014 - 12.0.4100.1 (X64) 

    Enterprise Edition: Core-based Licensing (64-bit) on Windows NT 6.3 <X64> 

  • 相关阅读:
    Windows Azure: Service Bus Queues 入门
    HTTP权威指南读书
    学习OpenWebkitSharp
    Intro to ASP.NET MVC 4 with Visual Studio [译五:添加一个模型]
    正则表达式
    运行page页面时的事件执行顺序
    C#cookie自动获取工具发布
    (译) Facebook工程师2012年小创意合集
    三层+临时表存储过程+巧用json+贱招图片加载+无刷新分页
    iOS开发那些事编写OCUnit测试方法应用测试方法
  • 原文地址:https://www.cnblogs.com/jenrrychen/p/6078525.html
Copyright © 2011-2022 走看看