Una delle funzionalità di EF Core presenti sin dalla prima versione, è la capacità di recuperare l'id appena inserito da una insert effettuata su una tabella che ha la chiave impostata come identity. Infatti, senza che noi facciamo nulla, dopo aver invocato il metodo SaveChanges, le entity appena inserite e con chiave identity hanno l'id popolato. Quando usiamo Sql Server, il modo in cui EF Core effettua questo recupero è funzionante, ma inefficiente. Per ottimizzare questo processo, EF 7 utilizza un codice SQL diverso dalle versioni precedenti, ma più efficiente.
Tuttavia, questo nuovo codice SQL ha problemi quando alla tabella sono collegati dei trigger. Per questo motivo, la classe TableBuilder è stata arricchita con il metodo HasTrigger. Se mappiamo l'entity usando questo metodo, EF utilizza il vecchio modo di recuperare l'id appena inserito, altrimenti EF utilizza il nuovo modo.
class MyContext : DbContext { public DbSet<Customer> Customers { get; set; } protected override void OnModelCreating(ModelBuilder modelBuilder) { base.OnModelCreating(modelBuilder); modelBuilder.Entity<Customer>(e => { e.ToTable(tb => tb.HasTrigger(?MyTrigger?)) }); } }
Dobbiamo tenere presente che questa nuova funzionalità introduce una breaking change. Se abbiamo un progetto con una versione di EF Core fino alla 6, con tabelle che hanno identity e trigger, nel momento in cui migriamo a EF 7, il codice comincierà a generare eccezioni in fase di insert in quanto verrà usato il nuovo metodo di recuperare il valore generato dal database. Per ripristinare il funzionamento corretto, dovremo aggiungere la chiamata a HasTrigger per le tabelle interessate.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Sopprimere gli errori di concorrenza quando si elimina una entity con Entity Framework 7
Semplificare il deployment di siti statici con Azure Static Web App
Specificare il numero di parentesi graffe nella string interpolation in combinazione con i string literal in C#
Organizzare i moduli sfruttando CommonJS
Gestire server e pc on premise con Azure Arc
Utilizzare la parola chiave nameof per referenziare i nomi dei parametri di un metodo in C#
Creare moduli CSS in React
Ottimizzare la persistenza che coinvolge un solo oggetto con Entity Framework Core 7
Utilizzare le collection expression in C#
Sviluppo applicazioni x-plat con .NET MAUI
Specificare il versioning nel path degli URL in ASP.NET Web API
Utilizzo di Set e Array in JavaScript
I più letti di oggi
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- Utilizzare i primary constructor in C#
- Installare le Web App site extension tramite una pipeline di Azure DevOps
- tra poco è la volta di #spa, #javascript e #angularjs per lo sviluppatore #aspnet con @sm15455: https://aspit.co/web15-live #aspilive
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- #vs2013, #windowsserver 2012 r2, #sqlserver 2014 e #tfs 2013 annunciati a #msteched. approfondimenti in seguito: https://aspit.co/amo