Una delle richieste più frequenti quando si realizza una pagina che gestisce un'entità è quella di sapere l'utente che ha creato l'entità e la data di creazione oltre all'utente e la data di ultima modifica. Se adottiamo le temporal table di SQL Server, queste informazioni possono essere recuperate molto velocemente.
Per quanto riguarda la data di creazione ci basta prendere la data di scrittura del primo record ordinando per data crescente e per la data di ultima modifica applichiamo lo stesso criterio ma ordinando per data decrescente. Per quanto riguarda l'utente, il ragionamento è il medesimo con l'accortezza di avere una colonna con il nome dell'utente nella tabella e di valorizzare l'utente che effettua l'azione ogni volta che andiamo ad aggiornare o inserire il record.
Grazie al supporto alle temporal tables di Entity Framework Core, possiamo recuperare facilmente con LINQ questi dati usando l'oepratore TemporalAll come possiamo vedere nel prossimo esempio.
var creationData = Context.People .TemporalAll() .Where(c => c.Id = 10) .OrderBy(c => EF.Property<DateTime>(c, "SysStartTime")) .Select(c => new { c.Username, CreationDate = EF.Property<DateTime>(c, "SysStartTime") }) .First(); var lastUpdateData = Context.People .TemporalAll() .Where(c => c.Id = 10) .OrderByDescending(c => EF.Property<DateTime>(c, "SysStartTime")) .Select(c => new { c.Username, CreationDate = EF.Property<DateTime>(c, "SysStartTime") }) .First();
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Eseguire le GitHub Actions offline
Generare file per il download da Blazor WebAssembly
Configurare policy CORS in Azure Container Apps
Ottimizzare la latenza in Blazor 8 tramite InteractiveAuto render mode
Evitare la command injection in un workflow di GitHub
Generare file PDF da Blazor WebAssembly con iText
Configurare dependabot per aggiornare le dipendenze di terze parti con GitHub Actions
Miglioramenti agli screen reader e al contrasto in Angular
Eseguire query verso tipi non mappati in Entity Framework Core
Utilizzare la libreria Benchmark.NET per misurare le performance
Assegnare un valore di default a un parametro di una lambda in C#
Applicare il versioning ai nostri endpoint ASP.NET Core Minimal API