sqlserver存储过程查询缓慢锁表分析

背景

生产环境用户查询项目文件夹报错:

bash 复制代码
org.springframework.dao.DataAccessResourceFailureException: 
### Error querying database.  Cause: com.microsoft.sqlserver.jdbc.SQLServerException: Read timed out
### The error may exist in com/ht/dp/doc/query/dao/DocQueryDao.xml
### The error may involve defaultParameterMap
### The error occurred while setting parameters
### SQL: EXEC Sp_GetCadFolderPriviAll ?, ?, ?,         ?, ?, ?, ?
### Cause: com.microsoft.sqlserver.jdbc.SQLServerException: Read timed out
; Read timed out; nested exception is com.microsoft.sqlserver.jdbc.SQLServerException: Read timed out

数据库执行存储过程发生了超时,根据用户反馈非必现

分析步骤

将存储过程解析为sql语句,打开sqlsever的执行计划:
可以看到16行 扫描行数达到了298w行,拿到该行:

OBJECT:(.dbo.PrjFolder.ix_PrjFolder_8 AS a), SEEK:(a.PrjID=@c_PrjID) ORDERED FORWARD

可以发现使用了项目id的关联:

这里添加了项目id,导致检索了全项目文件夹;通过分析业务,用户在查询父子级文件夹, JOIN Folder b ON a.ParentID = b.FolderID,已经满足了获取所有的父子级文件夹,无需增加项目id,按需关联条件。

相关推荐
jiayou647 小时前
KingbaseES 表级与列级加密完全指南
数据库·后端
GBASE1 天前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
xiezhr2 天前
逛GitHub发现了一款免费的带AI功能的数据库管理工具
数据库·ai编程·dba
吃糖的小孩2 天前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
笃行3503 天前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3503 天前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行3503 天前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库
SelectDB4 天前
阶跃星辰基于 SelectDB 构建 PB 级 Agent 可观测平台
大数据·数据库·aigc
这个DBA有点耶4 天前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构