细心很重要---猜猜这个SQL执行的什么意思
今天在帮客户做语句优化的时候,突然遇到这样一个语句,类似下面的例子(原语句是个update)
例子中使用AdventureWorks数据中的两个表。
productID 是[Production].[Product] 表的主键,在[Purchasing].[PurchaseOrderDetail] 中也建立了非聚集索引
select name,(select count(*) from [Purchasing].[PurchaseOrderDetail] where ProductID = ProductID) from [Production].[Product] where ProductID = 341
-----------------------------------此处请在心中默念 执行语句的意思,会选择什么样的索引?-----------------------------------------
首先来看一下 执行计划
[Purchasing].[PurchaseOrderDetail] 为什么走索引扫描? 这明显应该索引查找啊!
仔细看一下索引扫描的谓词
我靠自己和自己匹配去了 ? 和你想的一样么?
修改下代码~看看问题的所在
select name,(select count(*) from [Purchasing].[PurchaseOrderDetail]
where ProductID =[Production].[Product].ProductID)
from [Production].[Product] where ProductID = 341
这是一个由于粗心而犯下的错误,例子中是一个查询,实际中却是一个update 影响可想而知,而这个影响在存储过程中久久没能发现,要不是优化查看了执行计划关系开销,我扫一眼代码也想当然的觉得完全没问题!
问题得到解决,即解决的语句运行速度慢的问题,又找出了程序的BUG。
总结: 细心很重要!
分类:
SQL SERVER 应用
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· 展开说说关于C#中ORM框架的用法!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?