EF 6-Parameter-Sniffing
Beim Arbeiten mit großen dynamischen Abfragen in EF 6 kann es aufgrund von Parameter-Sniffing zu Leistungsproblemen kommen. Dies geschieht, wenn die Datenbank-Engine den Ausführungsplan einer Abfrage mit einem bestimmten Parametersatz beibehält und ihn auf nachfolgende Ausführungen anwendet, auch wenn sich die Parameter geändert haben.
Um dieses Problem zu beheben, bietet EF 6 eine Abfangfunktion Damit können Sie SQL-Befehle manipulieren, bevor sie ausgeführt werden. Dadurch können Sie Optionen wie „OPTION RECOMPILE“ in den Befehl einbetten.
Um diese Funktion zu nutzen, implementieren Sie den [IDbCommandInterceptor](https://docs.microsoft.com/en-us/dotnet/api /entityframework/system.data.entity.infrastructure.idbcommandinterceptor?view=ef6) Schnittstelle und überschreiben Sie die [ReaderExecuting](https://docs.microsoft.com/en-us/dotnet/api/entityframework/system.data.entity.infrastructure.idbcommandinterceptor.readerexecuting?view=ef6) Methode. Bei dieser Methode können Sie dem Befehl den gewünschten Abfragehinweis hinzufügen.
Hier ist eine Beispielimplementierung eines Interceptors, der den Hinweis „OPTION RECOMPILE“ zur Auswahl von Abfragen hinzufügt:
public class OptionRecompileHintDbCommandInterceptor : IDbCommandInterceptor { public void ReaderExecuting(DbCommand command, DbCommandInterceptionContext<DbDataReader> interceptionContext) { addQueryHint(command); } private static void addQueryHint(IDbCommand command) { if (command.CommandType != CommandType.Text || !(command is SqlCommand)) return; if (command.CommandText.StartsWith("select", StringComparison.OrdinalIgnoreCase) && !command.CommandText.Contains("option(recompile)")) { command.CommandText = command.CommandText + " option(recompile)"; } } }
Um den Interceptor zu verwenden, fügen Sie am Anfang Ihrer Bewerbung die folgende Zeile hinzu:
DbInterception.Add(new OptionRecompileHintDbCommandInterceptor());
Dadurch wird sichergestellt, dass die Option „OPTION Der Hinweis „RECOMPILE“ wird allen ausgewählten Abfragen hinzugefügt, die über EF 6 ausgeführt werden, wodurch die Auswirkungen des Parameter-Sniffings abgeschwächt werden.
Das obige ist der detaillierte Inhalt vonWie kann ich Leistungsprobleme beim EF 6-Parameter-Sniffing verhindern?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!