EF Core如何輸出日誌到Visual Studio的輸出視窗

來源:互聯網
上載者:User

標籤:oid   .data   ons   ext   div   framework   star   localhost   info   

我們在使用EF Core的時候,很多時候需要在Visual Studio的輸出視窗中知道EF Core在後台產生的SQL語句是什麼,這個需求可以通過自訂EF Core的ILoggerFactory和ILogger類來實現:

首先定義一個實現了ILogger介面的類EFLogger,主要目的是將EF Core產生的Log資訊輸出到Visual Studio的輸出視窗:

using Microsoft.Extensions.Logging;using System;using System.Diagnostics;namespace WebCore.Utils{    public class EFLogger : ILogger    {        protected string categoryName;        public EFLogger(string categoryName)        {            this.categoryName = categoryName;        }        public IDisposable BeginScope<TState>(TState state)        {            return null;        }        public bool IsEnabled(LogLevel logLevel)        {            return true;        }        public void Log<TState>(LogLevel logLevel, EventId eventId, TState state, Exception exception, Func<TState, Exception, string> formatter)        {            //通過Debugger.Log方法來將EF Core產生的Log資訊輸出到Visual Studio的輸出視窗            Debugger.Log(0, categoryName, "=============================== EF Core log started ===============================\r\n");            Debugger.Log(0, categoryName, formatter(state,exception)+"\r\n");            Debugger.Log(0, categoryName, "=============================== EF Core log finished ===============================\r\n");        }    }}

然後定義一個實現了ILoggerFactory介面的類EFLoggerFactory,用於建立上面定義的EFLogger類的執行個體:

using Microsoft.Extensions.Logging;namespace WebCore.Utils{    public class EFLoggerFactory : ILoggerFactory    {        public void AddProvider(ILoggerProvider provider)        {        }        public ILogger CreateLogger(string categoryName)        {            return new EFLogger(categoryName);//建立EFLogger類的執行個體        }        public void Dispose()        {        }    }}

最後在DbContext的OnConfiguring方法中,調用optionsBuilder.UseLoggerFactory來將EFLoggerFactory類的執行個體注入給EF Core,這樣所有DbContext的Log資訊,都會由EFLogger類輸出到Visual Studio的輸出視窗了。

using System;using Microsoft.EntityFrameworkCore;using Microsoft.EntityFrameworkCore.Metadata;using WebCore.Utils;namespace WebCore.Entities{    public partial class TestDBContext : DbContext    {        public TestDBContext()        {            this.Database.SetCommandTimeout(0);//設定SqlCommand永不逾時        }        public TestDBContext(DbContextOptions<TestDBContext> options)            : base(options)        {        }        public virtual DbSet<Person> Person { get; set; }        protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)        {            if (!optionsBuilder.IsConfigured)            {                optionsBuilder.UseLoggerFactory(new EFLoggerFactory());//將EFLoggerFactory類的執行個體注入給EF Core,這樣所有DbContext的Log資訊,都會由EFLogger類輸出到Visual Studio的輸出視窗了                optionsBuilder.UseSqlServer("Server=localhost;User Id=sa;Password=1qaz!QAZ;Database=TestDB");            }        }                protected override void OnModelCreating(ModelBuilder modelBuilder)        {            //省略代碼...        }    }}        

注意OnConfiguring這個方法是virtual的,所以我們也可以選擇在DbContext的子類中來重寫這個方法,在子類的OnConfiguring中注入EFLoggerFactory類的執行個體到DbContext。

 

最後我們來看看EF Core日誌輸出的效果,還是很規整的,最重要的是我們可以即時的得到EF Core在後台產生的SQL語句:

 

EF Core如何輸出日誌到Visual Studio的輸出視窗

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.