博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
not in 语句使程充崩溃
阅读量:5058 次
发布时间:2019-06-12

本文共 1167 字,大约阅读时间需要 3 分钟。

以前一直以为优化在百万级的表中才会有意义,这次的事件改变了我的看法

 

两张表 组织架构表(Organise 工资发放历史记录表 WagePerMonthHis

两张表通过 Organise.Item_id WagePerMonthHis.OrgIdS 进行关联

Organise(以下简称O)中大约有6000条记录11个字段 ,WagePerMonthHis(以下简称W)计有 125万条记录 25个字段

 

原程序中一段如下的语句

是查询所有不在W表的组织架构层级为2的记录

select OrgId as 公司编码,OrgName as 公司名称

from Organise

where OrgLev=2

and item_id not in

(select OrgidS from WagesPerMonthHis

where WagesYear='2010' and WagesMonth=

'01' Group by OrgidS,OrgNameS)

order by Orgid

 

语句执行要33秒之久,服务器的配置是比较高的:16核心4CPU,24G内存,且内存和CPU在执行时都没有出现瓶颈,开始以为是 (select OrgidS from WagesPerMonthHis

where WagesYear='2010' and WagesMonth=

'01' Group by OrgidS,OrgNameS)   这条语句执行缓慢所致,单独执行这条却发现执行速度很快,大约不到2秒就出来了,于是症结出来了,not in 这个全扫描关键词带来的性能下降.最直接的是导致页面失去响应,一个关键功能使用不了.

 

试了not exist语句,发现效果是一样的,并不象网上所说可以提高很多性能.

 

于是重新优化语句如下

select a.OrgId as 公司编码,a.OrgName as 公司名称,a.item_id

from Organise a

left outer join (select distinct b.OrgIdS from WagesPerMonthHis b

where WagesYear='2010' and WagesMonth='01') as b

on a.item_id = b.OrgidS

where a.OrgLev = 2

and b.OrgIdS is Null

order by 公司编码

 

改用左外连接
(
其实左连接也可以
)
,
整个语句执行速度为
400ms, 33
秒与
400ms
我想是很多人没想到的
.

转载于:https://www.cnblogs.com/georgehu/archive/2011/12/16/SQLnotin.html

你可能感兴趣的文章
20165235 第八周课下补做
查看>>
[leetcode] 1. Two Sum
查看>>
iOS 日常工作之常用宏定义大全
查看>>
PHP的SQL注入技术实现以及预防措施
查看>>
MVC Razor
查看>>
软件目录结构规范
查看>>
Windbg调试Sql Server 进程
查看>>
linux调度器系列
查看>>
mysqladmin
查看>>
解决 No Entity Framework provider found for the ADO.NET provider
查看>>
SVN服务器搭建和使用(三)(转载)
查看>>
Android 自定义View (三) 圆环交替 等待效果
查看>>
设置虚拟机虚拟机中fedora上网配置-bridge连接方式(图解)
查看>>
HEVC播放器出炉,迅雷看看支持H.265
查看>>
[置顶] Android仿人人客户端(v5.7.1)——人人授权访问界面
查看>>
Eclipse 调试的时候Tomcat报错启动不了
查看>>
【安卓5】高级控件——拖动条SeekBar
查看>>
ES6内置方法find 和 filter的区别在哪
查看>>
Android入门之文件系统操作(二)文件操作相关指令
查看>>
Android实现 ScrollView + ListView无滚动条滚动
查看>>