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性 ...
随机推荐
- 【使用篇二】SpringBoot整合Filter(2)
两种方式: 通过注解扫描完成 Filter 组件的注册 通过方法完成 Filter 组件的注册 一.通过注解扫描完成 Filter 组件的注册 1. 编写Filter类 /** * SpringBoo ...
- 刘长峰 js基础讲座笔记 课后作业
1.DataType Assert 数据类型断言 一.typeof : 判断变量的类型 ,返回字符串 typeof a 返回 'undefined' .'boolean' .'string' .' ...
- Shell变量——用户变量
1.Shell变量: (1)命令规则:由数字.字母.下划线组成,首字符不能为数字. (2)变量的默认类型都是字符串型,对于数值类型,则必须进行指定. (3)大小写敏感的,例如:ASD.asd.Asd是 ...
- Codeforces Round #545 (Div. 2) 交互 + 推公式
https://codeforces.com/contest/1138/problem/F 题意 有一条长为t的链,一个长为c的环,定义终点为链和环相连环上的第一个点,现在有10个人在起点,你每次可以 ...
- 1,[VS入门教程] 使用Visual Studio写c语言 入门与技巧精品文~~~~下载安装篇
Microsoft Visual Studio是微软(俗称巨硬)公司出品的强大IDE(Integrated Development Environment 集成开发环境),功能强大齐全,界面舒服之类的 ...
- 2,[VS入门教程] 使用Visual Studio写c语言 入门与技巧精品文~~~~优化篇
本文导航: 关闭界面特效以提高流畅度 解决调试时出现"无法查找或打开PDB文件"的符号问题 注册微软账号并在vs登录 使用Visual Studio Team Services,同 ...
- Elasticsearch由浅入深(十一)索引管理
索引的基本操作 创建索引 PUT /{index} { "settings": {}, "mappings": { "properties" ...
- SpringBoot集成Spring Security(3)——异常处理
源码地址:https://github.com/jitwxs/blog_sample 文章目录 一.常见异常二.源码分析三.处理异常不知道你有没有注意到,当我们登陆失败时候,Spring securi ...
- ROS融合IMU笔记
ROS官网有一个叫robot_pose_ekf的包,是专门处理传感器融合的包,具体介绍:http://wiki.ros.org/robot_pose_ekf 其中主要功能是订阅主题包括odom(里程计 ...
- 转载:string、const char*、 char* 、char[]相互转换
本文转自:https://blog.csdn.net/rongrongyaofeiqi/article/details/52442169 一:转化总结形式如下: 使用时,要对源格式和目标格式进行初始化 ...