.Net Core Entity Framework Core 的基礎封裝 -資料庫操作攔截器

来源:https://www.cnblogs.com/INetIMVC/p/18027178
-Advertisement-
Play Games

自己製作的一個基於Entity Framework Core 的資料庫操作攔截器,可以列印資料庫執行sql,方便開發調試,代碼如下: /// <summary> /// EF Core 的資料庫操作攔截器,用於在資料庫操作過程中進行日誌記錄和監視。 /// </summary> /// <remar ...


自己製作的一個基於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);
    }
}

運行結果如下:

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 前言 當前,微服務架構在很多公司都已經落地實施了,下麵用一張圖簡要概述下微服務架構設計中常用組件。不能說已經使用微服務好幾年了,結果對微服務架構沒有一個整體的認知,一個只懂搬磚的程式員不是一個好碼農。 流量入口Nginx 在上圖中可以看到,Nginx作為整個架構的流量入口,可以理解為一個外部的網關, ...
  • 之前給大家推薦過一些油管上的免費學習資源,如果您還沒有看過的話可以點擊這裡前往。 今天再給大家推薦一批Udemy上超高質量並且免費的編程課程,有需要的小伙伴可以學起來了。 1. JavaScript Essentials 第一門免費課程是:JavaScript Essentials。顧名思義,本課程 ...
  • 在 Java 中,LocalDateTime、Date 和 Instant 分別代表了不同的日期時間類型,它們之間有一些區別和適用場景。 Date: java.util.Date 是 Java 早期的日期時間類,它包含了日期和時間信息,但是在設計上存在一些問題,因此並不推薦在新的代碼中使用。 Dat ...
  • 序言 在數字時代,圖像生成技術正日益成為人工智慧領域的熱點。 本討論將重點聚焦於兩個備受矚目的模型:DALL-E和其他主流AI繪圖方法。 我們將探討它們的優勢、局限性以及未來的發展方向。通過比較分析,我們期望能夠更全面地瞭解這些技術,為未來的研究和應用提供啟示。 Q: 介紹一下 dall-e Ope ...
  • 簡介 git-commit-id-maven-plugin 是一個maven 插件,用來在打包的時候將git-commit 信息打進jar中。 這樣做的好處是可以將發佈的某版本和對應的代碼關聯起來,方便查閱和線上項目的維護。至於它的作用,用官方說法,這個功能對於大型分散式項目來說是無價的。 功能 你 ...
  • 1、下載安裝包首先、進入官網下載安裝包網址:https://www.python.org/downloads/windows/下載步驟:進入下載地址,根據自己的電腦系統選擇相應的python版本 選擇適配64位操作系統的版本(查看自己的電腦操作系統版本), 點擊下載安裝包 也可以下載我百度雲分享的安 ...
  • 在上篇文章中,我們介紹到在多線程環境下,如果編程不當,可能會出現程式運行結果混亂的問題。出現這個原因主要是,JMM 中主記憶體和線程工作記憶體的數據不一致,以及多個線程執行時無序,共同導致的結果。 ...
  • 本文分享自華為雲社區《Go併發範式 流水線和優雅退出 Pipeline 與 Cancellation》,作者:張儉。 介紹 Go 的併發原語可以輕鬆構建流數據管道,從而高效利用 I/O 和多個 CPU。 本文展示了此類pipelines的示例,強調了操作失敗時出現的細微之處,並介紹了乾凈地處理失敗的 ...
一周排行
    -Advertisement-
    Play Games
  • 隨著Aspire發佈preview5的發佈,Microsoft.Extensions.ServiceDiscovery隨之更新, 服務註冊發現這個屬於老掉牙的話題解決什麼問題就不贅述了,這裡主要講講Microsoft.Extensions.ServiceDiscovery(preview5)以及如何 ...
  • 概述:通過使用`SemaphoreSlim`,可以簡單而有效地限制非同步HTTP請求的併發量,確保在任何給定時間內不超過20個網頁同時下載。`ParallelOptions`不適用於非同步操作,但可考慮使用`Parallel.ForEach`,儘管在非同步場景中謹慎使用。 對於併發非同步 I/O 操作的數量 ...
  • 1.Linux上安裝Docken 伺服器系統版本以及內核版本:cat /etc/redhat-release 查看伺服器內核版本:uname -r 安裝依賴包:yum install -y yum-utils device-mapper-persistent-data lvm2 設置阿裡雲鏡像源:y ...
  • 概述:WPF界面綁定和渲染大量數據可能導致性能問題。通過啟用UI虛擬化、非同步載入和數據分頁,可以有效提高界面響應性能。以下是簡單示例演示這些優化方法。 在WPF中,當你嘗試綁定和渲染大量的數據項時,性能問題可能出現。以下是一些可能導致性能慢的原因以及優化方法: UI 虛擬化: WPF提供了虛擬化技術 ...
  • 引言 上一章節介紹了 TDD 的三大法則,今天我們講一下在單元測試中模擬對象的使用。 Fake Fake - Fake 是一個通用術語,可用於描述 stub或 mock 對象。 它是 stub 還是 mock 取決於使用它的上下文。 也就是說,Fake 可以是 stub 或 mock Mock - ...
  • 為.net6在CentOS7上面做準備,先在vmware虛擬機安裝CentOS 7.9 新建CentOS764位的系統 因為CentOS8不更新了,所以安裝7;簡單就一筆帶過了 選擇下載好的操作系統的iso文件,下載地址https://mirrors.aliyun.com/centos/7.9.20 ...
  • 經過前面幾篇的學習,我們瞭解到指令的大概分類,如:參數載入指令,該載入指令以 Ld 開頭,將參數載入到棧中,以便於後續執行操作命令。參數存儲指令,其指令以 St 開頭,將棧中的數據,存儲到指定的變數中,以方便後續使用。創建實例指令,其指令以 New 開頭,用於在運行時動態生成並初始化對象。方法調用指... ...
  • LiteDB 是一個輕量級的嵌入式 NoSQL 資料庫,其設計理念與 MongoDB 類似,但它是完全使用 C# 開發的,因此與 C# 應用程式的集成非常順暢。與 SQLite 相比,LiteDB 提供了 NoSQL(即鍵值對)的數據存儲方式,並且是一個開源且免費的項目。它適用於桌面、移動以及 We ...
  • 1 開源解析和拆分文檔 第三方的工具去對文件解析拆分,去將我們的文件內容給提取出來,並將我們的文檔內容去拆分成一個小的chunk。常見的PDF word mark down, JSON、HTML。都可以有很好的一些模塊去把這些文件去進行一個東西去提取。 優勢 支持豐富的文檔類型 每種文檔多樣化選擇 ...
  • OOM是什麼?英文全稱為 OutOfMemoryError(記憶體溢出錯誤)。當程式發生OOM時,如何去定位導致異常的代碼還是挺麻煩的。 要檢查OOM發生的原因,首先需要瞭解各種OOM情況下會報的異常信息。這樣能縮小排查範圍,再結合異常堆棧、heapDump文件、JVM分析工具和業務代碼來判斷具體是哪 ...