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
Miglioramenti agli screen reader e al contrasto in Angular
Gestire i null nelle reactive form tipizzate di Angular
Short-circuiting della Pipeline in ASP.NET Core
Ottimizzare il mapping di liste di tipi semplici con Entity Framework Core
Eseguire query manipolando le liste contenute in un oggetto mappato verso una colonna JSON
Definire stili a livello di libreria in Angular
Utilizzare Tailwind CSS all'interno di React: installazione
Visualizzare le change sul plan di Terraform tramite le GitHub Actions
Evitare il flickering dei componenti nel prerender di Blazor 8
Inizializzare i container in Azure Container Apps
Generare la software bill of material (SBOM) in GitHub
Code scanning e advanced security con Azure DevOps