Quando lavoriamo con SQL Server Compact 4.0 e Entity Framework dobbiamo tenere a mente alcune limitazioni derivanti dall'uso contemporaneo di queste tecnologie.
Entity Framework permette di avere entity con una proprietà che mappa su un campo di una tabella il cui valore è generato dal database. Con SQL Server Compact, solo i campi Identity sono supportati, la generazione lato server di GUID non è supportata quindi le nostre entity non devono contare su questa feature.
SQL Server Compact non supporta l'impostazione del timeout tramite Entity Framework. Se impostiamo la proprietà QueryTimeout dell'ObjectContext o CommandTimeout dell'EntityCommand su un valore diverso da 0, non otteniamo nessun errore in fase di compilazione, ma SQL Server Compact lancia un'eccezione a run time.
//Compilazione ma ritorna eccezione a run time ctx.QueryTimeout = 15;
Entity Framework supporta stringhe sia Unicode che non-Unicode. SQL Server Compact supporta solo stringhe Unicode.
L'ultima limitazione da evidenziare è che SQL Server Compact non supporta le Full Outer Join. Anche se LINQ to Entities non ci permette di specificare Full Outer Join, Entity SQL ce lo permette. Nel caso in cui ricorriamo alle Full Outer Join, SQL Server Compact lancia un'eccezione a run time.
Riferimenti utili
Dite addio ad Access con SQL Server Compact 4.0 (speciale)https://www.aspitalia.com/focuson/1207/Dite-Addio-Access-SQL-Server-Compact-4.0.aspx
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Gestire liste di tipi semplici con Entity Framework Core
Code scanning e advanced security con Azure DevOps
Migrare una service connection a workload identity federation in Azure DevOps
Supportare il sorting di dati tabellari in Blazor con QuickGrid
Hosting di componenti WebAssembly in un'applicazione Blazor static
Eseguire query verso tipi non mappati in Entity Framework Core
Cambiare la chiave di partizionamento di Azure Cosmos DB
Implementare il throttling in ASP.NET Core
Ottenere il contenuto di una cartella FTP con la libreria FluentFTP
Generare file PDF da Blazor WebAssembly con iText
Utilizzare HiLo per ottimizzare le insert in un database con Entity Framework
Sfruttare lo stream rendering per le pagine statiche di Blazor 8
I più letti di oggi
- PWAConf 2020 - Online
- Effettuare il binding di date in Blazor
- What's new in Azure Functions and Extensions
- Mantenere sempre reattiva una Lambda di AWS
- Proteggersi dagli attacchi di Open Redirect in ASP.NET Core MVC
- Gestire errori funzionali tramite exception in ASP.NET Core Web API
- Sblocca le performance della tua applicazione con .NET 8