My Life My Dream!

守信 求实 好学 力行
随笔 - 193, 文章 - 0, 评论 - 55, 阅读 - 34万
  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

组合索引字段顺序引发的死锁问题

Posted on   召冠  阅读(1119)  评论(0编辑  收藏  举报

组合主键、聚集索引引发的死锁问题,还是索引字段顺序、选择性的问题,切记。

image

 

-- SPID: 61
exec sp_executesql N'DELETE FROM SYLOCKAID WHERE MKID=@param0 AND DATACAT=@param1 AND DATAID=@param2',N'@param0 varchar(max) ,@param1 varchar(max) ,@param2 varchar(max) ',@param0='JCSF',@param1='JZSF_TD_YSZXZJB',@param2='201504cbb52e-9cfb-46d1-b2dd-c18a54f2db8501'

-- SPID: 69
exec sp_executesql N'DELETE FROM SYLOCKAID WHERE MKID=@param0 AND DATACAT=@param1 AND DATAID=@param2',N'@param0 varchar(max) ,@param1 varchar(max) ,@param2 varchar(max) ',@param0='JCSF',@param1='JZSF_TD_YSZXZJB',@param2='201502aa91d5-12e3-40b1-acd1-9c63109a36bc01'
sp_helpindex sylockaid;

index_name      index_description                                    index_keys
PK_SYLOCKAID    clustered, unique, primary key located on PRIMARY    MKID, DATACAT, DATAID
-- 调整索引字段顺序后,问题解决
alter table sylockaid 
    drop constraint PK_SYLOCKAID;

alter table sylockaid
    add constraint PK_SYLOCKAID primary key clustered(DATAID, MKID, DATACAT);
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
点击右上角即可分享
微信分享提示