.Net Core Entity Framework Core 的基础封装 -数据库操作拦截器
  J67OLajtwEzi 2024年02月22日 57 0

自己制作的一个基于Entity Framework Core 的数据库操作拦截器,可以打印数据库执行sql,方便开发调试,代码如下:

/// <summary>
/// EF Core 的数据库操作拦截器,用于在数据库操作过程中进行日志记录和监视。
/// </summary>
/// <remarks>
/// 作者:我只吃饭不洗碗
/// 创建日期:2024年1月29日
/// </remarks>
public class LoggingInterceptor : DbCommandInterceptor
{
    /// <summary>
    /// 在执行查询命令之前拦截并输出日志。
    /// </summary>
    /// <param name="command">要执行的查询命令。</param>
    /// <param name="eventData">命令事件数据。</param>
    /// <param name="result">拦截结果。</param>
    /// <returns>拦截结果。</returns>
    public override InterceptionResult<DbDataReader> ReaderExecuting(DbCommand command, CommandEventData eventData, InterceptionResult<DbDataReader> result)
    {
        var fullCommandText = command.CommandText;

        foreach (DbParameter param in command.Parameters)
        {
            var paramValue = param.Value is string ? $"'{param.Value}'" : param.Value.ToString();
            fullCommandText = fullCommandText.Replace(param.ParameterName, paramValue);
        }
        Console.WriteLine($"Executing query: {fullCommandText}");
        return base.ReaderExecuting(command, eventData, result);
    }

    /// <summary>
    /// 在执行非查询命令之前拦截并输出日志。
    /// </summary>
    /// <param name="command">要执行的非查询命令。</param>
    /// <param name="eventData">命令事件数据。</param>
    /// <param name="result">拦截结果。</param>
    /// <returns>拦截结果。</returns>
    public override InterceptionResult<int> NonQueryExecuting(DbCommand command, CommandEventData eventData, InterceptionResult<int> result)
    {
        var fullCommandText = command.CommandText;

        foreach (DbParameter param in command.Parameters)
        {
            var paramValue = param.Value is string ? $"'{param.Value}'" : param.Value.ToString();
            fullCommandText = fullCommandText.Replace(param.ParameterName, paramValue);
        }
        Console.WriteLine($"Executing non-query command: {fullCommandText}");
        return base.NonQueryExecuting(command, eventData, result);
    }

    /// <summary>
    /// 在执行标量查询命令之前拦截并输出日志。
    /// </summary>
    /// <param name="command">要执行的标量查询命令。</param>
    /// <param name="eventData">命令事件数据。</param>
    /// <param name="result">拦截结果。</param>
    /// <returns>拦截结果。</returns>
    public override InterceptionResult<object> ScalarExecuting(DbCommand command, CommandEventData eventData, InterceptionResult<object> result)
    {

        var fullCommandText = command.CommandText;

        foreach (DbParameter param in command.Parameters)
        {
            var paramValue = param.Value is string ? $"'{param.Value}'" : param.Value.ToString();
            fullCommandText = fullCommandText.Replace(param.ParameterName, paramValue);
        }
        Console.WriteLine($"Executing scalar query: {fullCommandText}");
        return base.ScalarExecuting(command, eventData, result);
    }
}

运行结果如下:

 

【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2024年02月22日 0

暂无评论

推荐阅读
  wJzKjCv7Jd8R   4小时前   7   0   0 .NET
J67OLajtwEzi