57 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C#
		
	
	
			
		
		
	
	
			57 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C#
		
	
	
using Microsoft.EntityFrameworkCore.Diagnostics;
 | 
						|
using System;
 | 
						|
using System.Collections.Generic;
 | 
						|
using System.Data.Common;
 | 
						|
using System.Text;
 | 
						|
using System.Text.RegularExpressions;
 | 
						|
using System.Threading;
 | 
						|
using System.Threading.Tasks;
 | 
						|
 | 
						|
namespace IRaCIS.Core.Infra.EFCore
 | 
						|
{
 | 
						|
    public class QueryWithNoLockDbCommandInterceptor : DbCommandInterceptor
 | 
						|
    {
 | 
						|
        private static readonly Regex TableAliasRegex =
 | 
						|
             new Regex(@"(?<tableAlias>(FROM|JOIN) \[[a-zA-Z]\w*\] AS \[[a-zA-Z]\w*\](?! WITH \(NOLOCK\)))",
 | 
						|
                RegexOptions.Multiline | RegexOptions.Compiled | RegexOptions.IgnoreCase);
 | 
						|
 | 
						|
        public override InterceptionResult<object> ScalarExecuting(DbCommand command, CommandEventData eventData, InterceptionResult<object> result)
 | 
						|
        {
 | 
						|
            command.CommandText = TableAliasRegex.Replace(
 | 
						|
                command.CommandText,
 | 
						|
                "${tableAlias} WITH (NOLOCK)"
 | 
						|
                );
 | 
						|
            return base.ScalarExecuting(command, eventData, result);
 | 
						|
        }
 | 
						|
 | 
						|
        public override ValueTask<InterceptionResult<object>> ScalarExecutingAsync(DbCommand command, CommandEventData eventData, InterceptionResult<object> result,
 | 
						|
            CancellationToken cancellationToken = new CancellationToken())
 | 
						|
        {
 | 
						|
            command.CommandText = TableAliasRegex.Replace(
 | 
						|
                command.CommandText,
 | 
						|
                "${tableAlias} WITH (NOLOCK)"
 | 
						|
                );
 | 
						|
            return base.ScalarExecutingAsync(command, eventData, result, cancellationToken);
 | 
						|
        }
 | 
						|
 | 
						|
        public override InterceptionResult<DbDataReader> ReaderExecuting(DbCommand command, CommandEventData eventData, InterceptionResult<DbDataReader> result)
 | 
						|
        {
 | 
						|
            command.CommandText = TableAliasRegex.Replace(
 | 
						|
                command.CommandText,
 | 
						|
                "${tableAlias} WITH (NOLOCK)"
 | 
						|
                );
 | 
						|
            return result;
 | 
						|
        }
 | 
						|
 | 
						|
        public override ValueTask<InterceptionResult<DbDataReader>> ReaderExecutingAsync(DbCommand command, CommandEventData eventData, InterceptionResult<DbDataReader> result,
 | 
						|
            CancellationToken cancellationToken = new CancellationToken())
 | 
						|
        {
 | 
						|
            command.CommandText = TableAliasRegex.Replace(
 | 
						|
                command.CommandText,
 | 
						|
                "${tableAlias} WITH (NOLOCK)"
 | 
						|
                );
 | 
						|
            return base.ReaderExecutingAsync(command, eventData, result, cancellationToken);
 | 
						|
        }
 | 
						|
    }
 | 
						|
}
 |