So protokollieren Sie generiertes SQL von DbContext.SaveChanges()
In Entity Framework (EF) können Sie die generierten SQL-Anweisungen einfach protokollieren durch Ihre DbContext.SaveChanges()-Methode. So geht's:
Verwenden der Database.Log-Eigenschaft:
In EF 6.0 und höher verfügt die Database-Klasse über eine Action
context.Database.Log = Console.WriteLine;
Verwendung von Interceptoren:
Wenn Sie mehr Fortgeschrittene benötigen Um die Protokollierungsfunktionen zu nutzen, können Sie einen Interceptor verwenden. Ein Interceptor ist eine Klasse, die von DbInterceptor erbt und deren verschiedene Methoden überschreibt. Eine solche Methode ist OnNonQueryExecuted, die immer dann aufgerufen wird, wenn eine Nicht-Abfrageanweisung ausgeführt wird (z. B. SaveChanges()).
In der OnNonQueryExecuted-Methode können Sie auf die ausgeführte SQL-Anweisung zugreifen und diese in einem protokollieren Datei, Datenbank oder an einem anderen Ort.
Beispiel Code:
Hier ist ein Beispiel für einen Interceptor, der die SQL-Anweisungen in einer Datei protokolliert:
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); } }
Sie können den Interceptor wie folgt registrieren:
Database.SetInitializer<MyContext>(null); Database.AddInterceptor(new SqlLoggerInterceptor(File.AppendText("log.txt")));
Das obige ist der detaillierte Inhalt vonWie protokolliere ich von DbContext.SaveChanges() generierte SQL-Anweisungen im Entity Framework?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!