Nello script #556 abbiamo introdotto il metodo LogTo per loggare le informazioni. In quello script abbiamo visto come inviare qualunque log emesso da Entity Framework Core verso output come la console e la finestra di output in Visual Studio. Entity Framework Core emette tantissime informazioni di logging che spesso non sono importanti durante lo sviluppo. Una delle cose più comuni in fase di sviluppo è visualizzare il codice SQL che viene generato sia in fase di lettura che in fase di scrittura e non altre informazioni. Per filtrare i messaggi di log che vengono inviati alla action passata in input al metodo LogTo possiamo ricorrere agli overload di questo metodo.
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder) { //overload 1 optionsBuilder.LogTo( Debug.WriteLine, new[] { RelationalEventId.CommandExecuted }, LogLevel.Debug); //overload 2 optionsBuilder.LogTo(Debug.WriteLine, (e, l) => l == LogLevel.Debug && e == RelationalEventId.CommandExecuted); }
In questo esempio possiamo visualizzare i due overload che permettono di scegliere le condizioni in base alle quali la action di log deve essere invocata.
Nel primo overload passiamo come secondo parametro un array di eventi che corrisponde ai tipi di evento per i quali vogliamo che la action di log venga invocata. Come tezo parametro passiamo il livello di debug necessario per invocare la action.
Nel secondo overload come secondo parametro specifichiamo una funzione che prende in input tipo di evento di log e il livello di log dell'evento e specifica una condizione in base alla quale invocare o meno la action di log.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Supportare lo HierarchyID di Sql Server in Entity Framework 8
Utilizzare l nesting nativo dei CSS
Recuperare automaticamente un utente e aggiungerlo ad un gruppo di Azure DevOps
Sfruttare al massimo i topic space di Event Grid MQTT
Estrarre dati randomici da una lista di oggetti in C#
Migliorare la scalabilità delle Azure Function con il Flex Consumption
Esporre i propri servizi applicativi con Semantic Kernel e ASP.NET Web API
Creare una libreria CSS universale: Clip-path
Gestire eccezioni nei plugin di Semantic Kernel in ASP.NET Core Web API
Eseguire query manipolando le liste contenute in un oggetto mappato verso una colonna JSON
Il nuovo controllo Range di Blazor 9
Recuperare App Service cancellati su Azure