집 >데이터 베이스 >MySQL 튜토리얼 >Entity Framework에서 DbContext.SaveChanges()에 의해 생성된 SQL 문을 기록하는 방법은 무엇입니까?
DbContext.SaveChanges()에서 생성된 SQL을 기록하는 방법
Entity Framework(EF)에서는 생성된 SQL 문을 쉽게 기록할 수 있습니다. DbContext.SaveChanges() 메서드를 사용합니다. 방법은 다음과 같습니다.
Database.Log 속성 사용:
EF 6.0 이상에서 Database 클래스에는 Action
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!