今天接到客户投诉说系统卡死了,经过一翻努力,终于解决了。现将解决步骤记录一下,以便下次参考:

因为客户系统集中在阿里云上面,使用的是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一例的更多相关文章

  1. 数据库优化实践【MS SQL优化开篇】

    数据库定义: 数据库是依照某种数据模型组织起来并存在二级存储器中的数据集合,此集合具有尽可能不重复,以最优方式为特定组织提供多种应用服务,其数据结构独立于应用程序,对数据的CRUD操作进行统一管理和控 ...

  2. MS SQL优化

    数据库优化实践[MS SQL优化开篇]   数据库定义: 数据库是依照某种数据模型组织起来并存在二级存储器中的数据集合,此集合具有尽可能不重复,以最优方式为特定组织提供多种应用服务,其数据结构独立于应 ...

  3. [置顶] 数据库优化实践【MS SQL优化开篇】

    数据库定义: 数据库是依照某种数据模型组织起来并存在二级存储器中的数据集合,此集合具有尽可能不重复,以最优方式为特定组织提供多种应用服务,其数据结构独立于应用程序,对数据的CRUD操作进行统一管理和控 ...

  4. MS SQL语句优化

    MS SQL Server查询优化方法查询速度慢的原因很多,常见如下几种 1.没有索引或者没有用到索引(这是查询慢最常见的问题,是程序设计的缺陷) 2.I/O吞吐量小,形成了瓶颈效应. 3.没有创建计 ...

  5. 复杂sql优化步骤与技巧

    数据管理型系统,由于用户的要求或者系统设计要求,会出现大量表进行join,还要进行大量统计性数据查询展示,甚至数据权限控制等操作.最后会导致sql异常复杂,随着数据量增加,或者只是应用到生产环境(正式 ...

  6. 温故知新-Mysql的体系结构概览&sql优化步骤

    文章目录 Mysql的体系结构概览 连接层 服务层 引擎层 存储层 存储引擎 存储引擎概述 存储引擎特性![存储引擎特性对比](https://img-blog.csdnimg.cn/20200510 ...

  7. SQL优化笔记—CPU优化

    补充:常规服务器动态管理对象包括,下面有些资料可能会应用到 dm_db_*:数据库和数据库对象dm_exec_*:执行用户代码和关联的连接dm_os_*:内存.锁定和时间安排dm_tran_*:事务和 ...

  8. 【转】使用SQL Tuning Advisor STA优化SQL

    SQL优化器(SQL Tuning Advisor STA)是Oracle10g中推出的帮助DBA优化工具,它的特点是简单.智能,DBA值需要调用函数就可以给出一个性能很差的语句的优化结果.下面介绍一 ...

  9. SQL Server数据库性能优化之索引篇【转】

    http://www.blogjava.net/allen-zhe/archive/2010/07/23/326966.html 性能优化之索引篇 近期项目需要, 做了一段时间的SQL Server性 ...

随机推荐

  1. SQL Server 迁移数据库 (一)导入和导出

    今天正好换服务器,记录一下迁移数据库的过程. 以前经常用备份还原法,今天试试‘SQL Server 2016 导入和导出数据’这个看怎么玩. 1. 建数据库结构 1.1 在需要迁移的数据库名字上右击, ...

  2. Linux性能优化实战学习笔记:第三十八讲

    一.上节回顾 上一节,我们学习了 DNS 性能问题的分析和优化方法.简单回顾一下,DNS 可以提供域名和 IP 地址的映射关系,也是一种常用的全局负载均衡(GSLB)实现方法. 通常,需要暴露到公网的 ...

  3. [LeetCode] 827. Making A Large Island 建造一个巨大岛屿

    In a 2D grid of 0s and 1s, we change at most one 0 to a 1. After, what is the size of the largest is ...

  4. nginx小知识

    What Nginx是一款轻量级的Web服务器.反向代理服务器,由于它的内存占用少,启动极快,高并发能力强,在互联网项目中广泛应用. 反向代理 当我们在外网访问百度的时候,其实会进行一个转发,代理到内 ...

  5. shell 中 贪婪匹配 和 非贪婪匹配

    举个栗子: v=jfedu.shiyiwen.com echo ${v%.*} 一个%为非贪婪匹配,即匹配最短结果.%从右到左进行非贪婪匹配,匹配什么呢? 匹配已 .*的字符. 那么当然是匹配到了.c ...

  6. django实战(五)--增加数据

    urls.py urlpatterns=[ path('curd/add/',views.curd_add,name='curdadd'), path('curd/saveadd/',views.cu ...

  7. SpringBoot第二十篇:初识ActiveMQ

    本文是作者之前写的关于 ActiveMQ 的一篇文章.此处为了保证该系列文章的完整性,故此处重新引入. 一.消息中间件的介绍 介绍 消息队列 是指利用 高效可靠 的 消息传递机制 进行与平台无关的 数 ...

  8. [JAVA] 日常填坑 java.lang.SecurityException: Prohibited package name: java.xxx

    java虚拟机不允许包名以java开头. https://blog.csdn.net/sinat_28690417/article/details/72328547

  9. 百度前端技术学院-task1.4源代码

    任务描述 实现如 示例图(点击打开) 的效果 灰色元素水平垂直居中,有两个四分之一圆位于其左上角和右下角. 任务注意事项 思考不同情况下(如灰色高度是根据内容动态变化的)水平垂直居中的解决方案. 动手 ...

  10. Java中转换为十六进制的几种实现

    public class HexUtil { private static final String[] DIGITS_UPPER = {"0", "1", & ...