架构师_程序员_码农网

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

搜索
查看: 9|回复: 0

[技巧] EF Core 高并发查询之 WITH(NOLOCK) 优化

[复制链接]
发表于 2 小时前 | 显示全部楼层 |阅读模式
需求:有些数据允许脏读,例如:文章内容、阅读量、评论等信息,他不像金融类的数据那么严谨。为了提升查询性能,可能是使用 ReadUncommitted 事务,但是 SqlTransaction 和 TransactionScope 存在泄漏隔离级别的 BUG,至今未修复,所以,考虑使用 WITH(NOLOCK) 方案。

回顾:
Entity Framework 查询优化之 WITH(NOLOCK)
https://www.itsvse.com/thread-9513-1-1.html

.NET/C# 使用 SqlScriptDOM  解析执行的 SQL 语句
https://www.itsvse.com/thread-11222-1-1.html
SqlTransaction 和 TransactionScope 泄漏隔离级别(该 BUG 已经存在 8 年,至今未修复!我估计很多人可能会受到影响,但却没有意识到这一点):超链接登录可见。

本文需要引用 SqlScriptDOM 来解析 SQL 语句并添加 WITH(NOLOCK),参考开源项目:超链接登录可见。

Nuget 引用如下:
新建 AllowDirtyReadAttribute.cs 特性,代码如下:
新建 WithNoLockInterceptor 来重写 DbCommandInterceptor 中的某些方法,代码如下:
注入到 EF Core 中,配置如下:
使用,在控制器方法上面添加 [AllowDirtyRead] 即可。

原始 SQL 语句:
SELECT   [o].[Id],
         [o].[CustomerName],
         [o0].[Id],
         [o0].[OrderId],
         [o0].[Product]
FROM     [Orders] AS [o]
             LEFT OUTER JOIN
         [OrderLines] AS [o0]
         ON [o].[Id] = [o0].[OrderId]
WHERE    [o].[Id] = 1
ORDER BY [o].[Id];
添加 NOLOCK 后生成的语句:
SELECT   [o].[Id],
         [o].[CustomerName],
         [o0].[Id],
         [o0].[OrderId],
         [o0].[Product]
FROM     [Orders] AS [o] WITH (NOLOCK)
         LEFT OUTER JOIN
         [OrderLines] AS [o0] WITH (NOLOCK)
         ON [o].[Id] = [o0].[OrderId]
WHERE    [o].[Id] = 1
ORDER BY [o].[Id];




上一篇:(MSSQL)SQL Server Full-Text 全文搜索、全文索引
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

免责声明:
码农网所发布的一切软件、编程资料或者文章仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。如有侵权请邮件与我们联系处理。

Mail To:help@itsvse.com

QQ|小黑屋|架构师 ( 鲁ICP备14021824号-2 )|网站地图

GMT+8, 2026-6-12 23:26

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表