La classe DbContext ci permette di accedere alle principali funzionalità di Entity Framework. Tuttavia, questa classe non copre il 100% delle funzionalità. Ad esempio, non possiamo eseguire query sfruttando Entity SQL così come non possiamo chiamare il metodo SaveChanges specificando se applicare le modifiche agli oggetti in memoria dopo che gli stessi oggetti sono stati persistiti sul database.
Per eseguire queste operazioni dobbiamo obbligatoriamente ricorrere alla classe ObjectContext. Un'istanza della classe DbContext ingloba internamente un'istanza della classe ObjectContext ed espone questa istanza attraverso la proprietà ObjectContext dell'interfaccia IObjectContextAdapter che la classe DbContext implementa.
Questo significa che semplicemente castando l'oggetto di tipo DbContext all'interfaccia IObjectContextAdapter possiamo poi recuperare l'istanza dell'ObjectContext attraverso l'omonima proprietà così come mostrato nel seguente codice.
using (var ctx = new MyContext()){
ObjectContext context = ((IObjectContextAdapter)ctx).ObjectContext;
...
}Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Referenziare un package NuGet in una file based app .NET
Creare un agente A2Acon Azure Logic Apps
Evitare la compressione degli artefatti in un workflow di GitHub
Evitare memory leaks nelle closure JavaScript
Realizzare un accordion con gli elementi HTML details e summary
Recuperare gli audit log in Azure DevOps
Utilizzare Containers in .NET Aspire
Mischiare codice server side e client side in una query LINQ con Entity Framework
Ridimensionamento automatico input tramite CSS
Filtrare i dati in ASP.NET Core usando OpenTelemetry su Azure Monitor
Eliminare record doppi in Sql Server
Utilizzo delle stepped value functions nel CSS


