分享一个 .NET 通过监听器拦截 EF 消息写日志的详细例子
创始人
2025-01-11 09:36:57
0

image

前言

EF 开发效率确实很高也很便捷,但当它发生错误时,也挺让人头疼的,为什么?因为 EF 就像是一个黑盒子,一切全被封装起来,出错的时候很难定位原因,如果能够知道并打印 EF 生成的 SQL 语句,对于定位 EF 错误,就很有帮助。

程序员的才智是无限的,虽然 EF 有这个那个的问题,但程序员却总比这些问题多一个办法。

下面分享一个 .NET 通过监听器拦截 EF 消息写日志的详细例子。

Step By Step 步骤

  1. 创建自定义监听器类,拦截 EF 的命令执行事件(留意注释

    ///  /// 监听并写 EF 生成的 SQL 到日志 ///  public class EFIntercepterLogging : IDbCommandInterceptor {     ///      /// 实现接口的 NonQueryExecuting 方法     ///      ///      ///      public void NonQueryExecuting(         DbCommand command,          DbCommandInterceptionContext interceptionContext)     {         LogWhenExecuting(command, interceptionContext);     }      ///      /// 实现接口的 NonQueryExecuted 方法     ///      ///      ///      public void NonQueryExecuted(         DbCommand command,          DbCommandInterceptionContext interceptionContext)     {         LogIfError(command, interceptionContext);     }      ///      /// 实现接口的 ReaderExecuting 方法     ///      ///      ///      public void ReaderExecuting(         DbCommand command,          DbCommandInterceptionContext interceptionContext)     {         LogWhenExecuting(command, interceptionContext);     }      ///      /// 实现接口的 ReaderExecuted 方法     ///      ///      ///      public void ReaderExecuted(         DbCommand command,          DbCommandInterceptionContext interceptionContext)     {         LogIfError(command, interceptionContext);     }      ///      /// 实现接口的 ScalarExecuting 方法     ///      ///      ///      public void ScalarExecuting(         DbCommand command,          DbCommandInterceptionContext interceptionContext)     {         LogWhenExecuting(command, interceptionContext);     }      ///      /// 实现接口的 ScalarExecuted 方法     ///      ///      ///      public void ScalarExecuted(         DbCommand command,          DbCommandInterceptionContext interceptionContext)     {         LogIfError(command, interceptionContext);     }      ///      /// 写 EF 执行中的 SQL 日志,Debug 级别,用在 Executing 方法     ///      ///      ///      ///      private void LogWhenExecuting(         DbCommand command,          DbCommandInterceptionContext interceptionContext)     {         Logger.DebugFormat("Executing the following SQL: [{0}]", command.CommandText);     }      ///      /// 出现异常时写日志到 Log4net     ///      ///      ///      ///      private void LogIfError(         DbCommand command,          DbCommandInterceptionContext interceptionContext)     {         if (interceptionContext.Exception != null)         {             var errMsg = new StringBuilder(16);             errMsg.AppendLine("Error occurred when executing the following SQL: ");             errMsg.AppendLine(command.CommandText);             foreach (DbParameter param in command.Parameters)             {                 errMsg.AppendLine($"ParameterName:[{param.ParameterName}] -- DbType:[{param.DbType}] -- Value:[{param.Value}]");             }             Logger.Error(errMsg, interceptionContext.Exception);         }     } }  
  2. 在 Global.asax 中的 Application_Start 方法注册监听器

    protected void Application_Start() {     AreaRegistration.RegisterAllAreas();     FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);     RouteConfig.RegisterRoutes(RouteTable.Routes);     BundleConfig.RegisterBundles(BundleTable.Bundles);     //autofac注册     AutofacConfig.RegisterConfig();     //注册 EF log 监听器     DbInterception.Add(new EFIntercepterLogging()); } 
  3. 这样就实现了监听器拦截 EF 消息写日志的功能,当运行程序执行 EF 语句时,就会自动将 EF 生成的 SQL 写到日志文件中

  4. 总结

    通过实现自定义监听器类并注册监听器,可以跟踪和记录 EF 的操作和事件,在开发过程中更好地了解和调试 EF 的行为,不失为排查 EF 问题和优化 EF 性能的一个好方法。

    我是老杨,一个奋斗在一线的资深研发老鸟,让我们一起聊聊技术,聊聊程序人生,共同学习,

    相关内容

    热门资讯

    第9分钟了解!兴动互娱游戏辅助... 第9分钟了解!兴动互娱游戏辅助器好用吗(辅助)中至鹰潭麻将开挂辅助修改器-总是存在有修改器1)兴动互...
    透视辅助!微乐小程序黑科技免费... 透视辅助!微乐小程序黑科技免费(透视)微乐麻将自建房app(原来是有辅助插件)-哔哩哔哩在进入软件靠...
    第四分钟了解!川娱竞技有挂透视... 第四分钟了解!川娱竞技有挂透视脚本(辅助)果果互娱开挂辅助工具-原来是真的辅助1、游戏颠覆性的策略玩...
    透视玄学!微乐小程序黑科技免费... 透视玄学!微乐小程序黑科技免费(透视)微乐自建房免费黑科技下载(其实存在有辅助工具)-哔哩哔哩亲,关...
    第一分钟了解!中至赣牌圈祈福转... 第一分钟了解!中至赣牌圈祈福转运(辅助)卡贝大厅开挂辅助安装-原来真的有辅助1)中至赣牌圈祈福转运有...
    透视最新!微信微乐游戏辅助脚本... 透视最新!微信微乐游戏辅助脚本(透视)微乐房间辅助工具在哪下载(果然存在有辅助修改器)-哔哩哔哩1、...
    第7分钟了解!yy软件辅助(辅... 第7分钟了解!yy软件辅助(辅助)鸿鹄开挂辅助软件-都是是真的神器1、用户打开应用后不用登录就可以直...
    透视挂!微信微乐游戏辅助脚本(... 透视挂!微信微乐游戏辅助脚本(透视)微乐自建房辅助工具(总是真的有辅助辅助器)-哔哩哔哩1、很好的工...
    透视好牌!微信微乐游戏辅助脚本... 透视好牌!微信微乐游戏辅助脚本(透视)微信微乐挂有没有(一贯真的有辅助辅助器)-哔哩哔哩1. 选牌创...
    十分钟了解!潮汕馆插件(辅助)... 十分钟了解!潮汕馆插件(辅助)正大互娱开挂辅助工具-总是真的是有安装一、潮汕馆插件游戏安装教程牌型概...