>데이터 베이스 >MySQL 튜토리얼 >Entity Framework에서 DbContext.SaveChanges()에 의해 생성된 SQL 문을 기록하는 방법은 무엇입니까?

Entity Framework에서 DbContext.SaveChanges()에 의해 생성된 SQL 문을 기록하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2025-01-04 16:23:41785검색

How to Log SQL Statements Generated by DbContext.SaveChanges() in Entity Framework?

DbContext.SaveChanges()에서 생성된 SQL을 기록하는 방법

Entity Framework(EF)에서는 생성된 SQL 문을 쉽게 기록할 수 있습니다. DbContext.SaveChanges() 메서드를 사용합니다. 방법은 다음과 같습니다.

Database.Log 속성 사용:

EF 6.0 이상에서 Database 클래스에는 Action Log라는 속성입니다. 이 속성을 콘솔에 쓰는 함수로 설정하면 생성된 SQL 문을 기록할 수 있습니다.

context.Database.Log = Console.WriteLine;

인터셉터 사용:

더 고급 기능이 필요한 경우 로깅 기능을 사용하려면 인터셉터를 사용할 수 있습니다. 인터셉터는 DbInterceptor를 상속하고 다양한 메서드를 재정의하는 클래스입니다. 그러한 메서드 중 하나가 OnNonQueryExecuted입니다. 이 메서드는 쿼리가 아닌 문(예: SaveChanges())이 실행될 때마다 호출됩니다.

OnNonQueryExecuted 메서드에서는 실행된 SQL 문에 액세스하여 이를 로그할 수 있습니다. 파일, 데이터베이스 또는 기타 위치.

예 코드:

다음은 SQL 문을 파일에 기록하는 인터셉터의 예입니다.

public class SqlLoggerInterceptor : DbInterceptor
{
    private readonly TextWriter _logWriter;

    public SqlLoggerInterceptor(TextWriter logWriter)
    {
        _logWriter = logWriter;
    }

    public override void OnNonQueryExecuted(DbCommand command, DbCommandInterceptionContext interceptionContext)
    {
        _logWriter.WriteLine(command.CommandText);
    }
}

다음과 같이 인터셉터를 등록할 수 있습니다.

Database.SetInitializer<MyContext>(null);
Database.AddInterceptor(new SqlLoggerInterceptor(File.AppendText("log.txt")));

위 내용은 Entity Framework에서 DbContext.SaveChanges()에 의해 생성된 SQL 문을 기록하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.