MS Sql 优化步骤及优化not in一例
今天接到客户投诉说系统卡死了,经过一翻努力,终于解决了。现将解决步骤记录一下,以便下次参考:
因为客户系统集中在阿里云上面,使用的是ms sql2008数据库,上面有N个客户,一下子无法知道是哪个客户。
第一步,先打开任务管理器,看看cpu使用情况,

一看就知道是 ms sql server有大查询占用了所有的CPU时间,所以卡死系统 。
第二步,打开ms sql server 的活动监控器,查看是哪条语句卡死。
打开活动监控器的方法。在

中的对象资源管理器,找到服务器,右击。可以看到“活动监控器”,或者用快捷键ctrl+alt+A .。

第三步,找到有问题 的语句。点开进程, 通过任务状态,筛选 running的进程 。

逐个查看运行中的语句,分析最有可能卡住 系统的语句,去运行一下。就可以查到是哪条语句卡住 了。
我的情况就是下面这句:
SELECT A.cCrm, A.cCode AS cOrderCode, A.dRequire, A.dSubmit, B.*,
C.cCode AS cProductCode, B.cProductSpec BcProductSpec, A.dConfirm,
A.dCheck1, C.cParamter, C.cSpec AS cProductSpec, C.cColor, A.cCreator
FROM Orders A WITH ( NOLOCK )
LEFT JOIN Orders_Product B WITH ( NOLOCK ) ON A.cID = B.cOrdersID
LEFT JOIN Product C WITH ( NOLOCK ) ON B.cProductID = C.cID
LEFT JOIN (
--生产的产品ID
SELECT DISTINCT A1.cProductID
FROM dbo.Product_Item A1
LEFT JOIN dbo.Orders_ProductItem A2 ON A1.cProductID = A2.cProductID
WHERE A1.iProduct != 0
) D ON B.cProductID = D.cProductID
WHERE 1 = 1
AND B.cProductID = D.cProductID
AND A.iCancel = ''
AND ( iStatus = 30
OR ( iStatus = 20
AND iNewCRM != 1
AND NOT EXISTS ( SELECT 1
FROM Orders_ProductItem WITH ( NOLOCK )
WHERE iCustom = 1
AND cOrdersID = A.cID )
)
)
AND ( A.iStatusPP = 0
OR A.iStatusPP = 1
)
AND NOT EXISTS ( SELECT 1
FROM MOrders_Product
LEFT JOIN dbo.MOrders ON MOrders.cID = MOrders_Product.cMOrdersID
WHERE cOrdersProductID = B.cSubID
AND dbo.MOrders.iStatus != 2 )
AND B.iCancelM = 0
AND B.cSubID NOT IN (
SELECT B.cOrdersProductID
FROM DOrders A
LEFT JOIN DOrders_Sub B ON A.cID = B.cDOrdersID
WHERE iStatus = 3 )
ORDER BY A.dUDate DESC;
经过分析定位到:not in 导至系统卡顿:
B.cSubID NOT IN (
SELECT B.cOrdersProductID
FROM DOrders A
LEFT JOIN DOrders_Sub B ON A.cID = B.cDOrdersID
WHERE iStatus = 3
将not in 改为 not exists问题得以解决,系统正常运作。
改后的代码为:
SELECT A.cCrm, A.cCode AS cOrderCode, A.dRequire, A.dSubmit, B.*,
C.cCode AS cProductCode, B.cProductSpec BcProductSpec, A.dConfirm,
A.dCheck1, C.cParamter, C.cSpec AS cProductSpec, C.cColor, A.cCreator
FROM Orders A WITH ( NOLOCK )
LEFT JOIN Orders_Product B WITH ( NOLOCK ) ON A.cID = B.cOrdersID
LEFT JOIN Product C WITH ( NOLOCK ) ON B.cProductID = C.cID
LEFT JOIN (
--生产的产品ID
SELECT DISTINCT A1.cProductID
FROM dbo.Product_Item A1
LEFT JOIN dbo.Orders_ProductItem A2 ON A1.cProductID = A2.cProductID
WHERE A1.iProduct != 0
) D ON B.cProductID = D.cProductID
WHERE 1 = 1
AND B.cProductID = D.cProductID
AND A.iCancel = ''
AND ( iStatus = 30
OR ( iStatus = 20
AND iNewCRM != 1
AND NOT EXISTS ( SELECT 1
FROM Orders_ProductItem WITH ( NOLOCK )
WHERE iCustom = 1
AND cOrdersID = A.cID )
)
)
AND ( A.iStatusPP = 0
OR A.iStatusPP = 1
)
AND NOT EXISTS ( SELECT 1
FROM MOrders_Product
LEFT JOIN dbo.MOrders ON MOrders.cID = MOrders_Product.cMOrdersID
WHERE cOrdersProductID = B.cSubID
AND dbo.MOrders.iStatus != 2 )
AND B.iCancelM = 0
AND NOT EXISTS (
SELECT 1
FROM DOrders AA
LEFT JOIN DOrders_Sub BB ON AA.cID = BB.cDOrdersID
WHERE iStatus = 3 AND B.cSubID=bb.cOrdersProductID)
ORDER BY A.dUDate DESC;
原因可以参考以下文章:
https://www.cnblogs.com/totian/p/7597300.html
https://blog.csdn.net/zxu_1995/article/details/82388395
MS Sql 优化步骤及优化not in一例的更多相关文章
- 数据库优化实践【MS SQL优化开篇】
数据库定义: 数据库是依照某种数据模型组织起来并存在二级存储器中的数据集合,此集合具有尽可能不重复,以最优方式为特定组织提供多种应用服务,其数据结构独立于应用程序,对数据的CRUD操作进行统一管理和控 ...
- MS SQL优化
数据库优化实践[MS SQL优化开篇] 数据库定义: 数据库是依照某种数据模型组织起来并存在二级存储器中的数据集合,此集合具有尽可能不重复,以最优方式为特定组织提供多种应用服务,其数据结构独立于应 ...
- [置顶] 数据库优化实践【MS SQL优化开篇】
数据库定义: 数据库是依照某种数据模型组织起来并存在二级存储器中的数据集合,此集合具有尽可能不重复,以最优方式为特定组织提供多种应用服务,其数据结构独立于应用程序,对数据的CRUD操作进行统一管理和控 ...
- MS SQL语句优化
MS SQL Server查询优化方法查询速度慢的原因很多,常见如下几种 1.没有索引或者没有用到索引(这是查询慢最常见的问题,是程序设计的缺陷) 2.I/O吞吐量小,形成了瓶颈效应. 3.没有创建计 ...
- 复杂sql优化步骤与技巧
数据管理型系统,由于用户的要求或者系统设计要求,会出现大量表进行join,还要进行大量统计性数据查询展示,甚至数据权限控制等操作.最后会导致sql异常复杂,随着数据量增加,或者只是应用到生产环境(正式 ...
- 温故知新-Mysql的体系结构概览&sql优化步骤
文章目录 Mysql的体系结构概览 连接层 服务层 引擎层 存储层 存储引擎 存储引擎概述 存储引擎特性是Oracle10g中推出的帮助DBA优化工具,它的特点是简单.智能,DBA值需要调用函数就可以给出一个性能很差的语句的优化结果.下面介绍一 ...
- SQL Server数据库性能优化之索引篇【转】
http://www.blogjava.net/allen-zhe/archive/2010/07/23/326966.html 性能优化之索引篇 近期项目需要, 做了一段时间的SQL Server性 ...
随机推荐
- 【Excel】截取字符 LEFT(A1,2) RIGHT(A1,2) MID(SHEET1!E2,1,9)
LEFT(A1,2)从左边取两个字符 RIGHT(A1,2)从右边取两个字符 MID(SHEET1!E2,1,9)从sheet1表E2单元格中第一位起后9位 可以嵌套
- 2.GO-可变参数函数、匿名函数和函数变量
2.1.可变参数函数 可变参数指参数的个数可以是任意个 可变参数必须在参数列表最后的位置,在参数名和类型之间添加三个点表示可变参数函数 声明函数时,在函数体把可变参数当作切片使用即可 package ...
- [LeetCode] 923. 3Sum With Multiplicity 三数之和的多种情况
Given an integer array A, and an integer target, return the number of tuples i, j, k such that i &l ...
- OSG :三维无序离散点构建Delaunay三角网
利用OSG的osgUtil库里面的DelaunayTriangulator类. points是需要构建三角网的点 osgUtil::DelaunayTriangulator* trig = new o ...
- Docker笔记:常用服务安装——Nginx、MySql、Redis(转载)
转载地址:https://www.cnblogs.com/spec-dog/p/11320513.html 开发中经常需要安装一些常用的服务软件,如Nginx.MySql.Redis等,如果按照普通的 ...
- Vue.js 源码分析(十二) 基础篇 组件详解
组件是可复用的Vue实例,一个组件本质上是一个拥有预定义选项的一个Vue实例,组件和组件之间通过一些属性进行联系. 组件有两种注册方式,分别是全局注册和局部注册,前者通过Vue.component() ...
- Django学习——用户自定义models问题解决
一.问题在Django中使用自定义的model的时候会出现下面的错误 ERRORS: auth.User.groups: (fields.E304) Reverse accessor for 'Use ...
- golang 学习笔记 ---new()和 make()的区别详解
概述 Go 语言中的 new 和 make 一直是新手比较容易混淆的东西,咋一看很相似.不过解释两者之间的不同也非常容易. new 的主要特性 首先 new 是内建函数,你可以从 http://gol ...
- Java8 Optional总结
分类专栏: Java 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/HEYUTAO00 ...
- layui 在页面弹出小窗口,并关闭
function showdialog() { layer.open({ type: 2, title: '发起调度', shadeClose: true, shade: 0.8, area: [ ...