Un sito ospitato all'intero di Azure Web Site consente di sfruttare SQL Server Compact come motore di gestione dei propri database, grazie al fatto che il runtime è aggiornato ad ASP.NET 4.5. SQL Server Compact è un motore che gira in-process rispetto al sito web, quindi è l'ideale in caso si voglia una soluzione economica per lo storage, ma comunque con performance più che dignitose.
Di default, però, questo database non funzionerà, dandoci errore, se il deployment viene effettuato direttamente da Visual Studio.
Purtroppo, è necessario copiare manualmente alcuni file nella directory \bin\ del sito, esattamente tutti quelli posizionati sotto il percorso C:\Program Files\Microsoft SQL Server Compact Edition\v4.0\Private.
Questa operazione può essere fatta collegandosi via FTP (o usando WebMatrix 2) e posizionandoci nel percorso /site/wwwroot/bin.
Infine, è necessario registrare il provider all'interno di quelli supportati, aggiungendolo al web.config:
<configuration> .. <system.data> <DbProviderFactories> <remove invariant="System.Data.SqlServerCe.4.0" /> <add name="Microsoft SQL Server Compact Data Provider 4.0" invariant="System.Data.SqlServerCe.4.0" description=".NET Framework Data Provider for Microsoft SQL Server Compact" type="System.Data.SqlServerCe.SqlCeProviderFactory, System.Data.SqlServerCe, Version=4.0.0.1, Culture=neutral, PublicKeyToken=89845dcd8080cc91" /> </DbProviderFactories> </system.data> </configuration>
Così facendo, sarà possibile sfruttare SQL Server Compact nei nostri progetti basati su ASP.NET, anche con Entity Framework 4 o 5, con una buona compatibilità con SQL Server e SQL Azure, nel caso in cui dovessimo, rispettivamente, far girare l'app in locale o aver bisogno di ulteriore scalabilità.
Il database può essere copiato manualmente, sempre via FTP, così da portare ad intervalli una copia dei dati in locale, anche per fini di backup.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Sostituire la GitHub Action di login su private registry
Creare form tipizzati con Angular
Reactive form tipizzati con modellazione del FormBuilder in Angular
Paginare i risultati con QuickGrid in Blazor
Trasformare qualsiasi backend in un servizio GraphQL con Azure API Management
Aggiungere interattività lato server in Blazor 8
Short-circuiting della Pipeline in ASP.NET Core
Utilizzare Model as a Service su Microsoft Azure
Ottimizzare la latenza in Blazor 8 tramite InteractiveAuto render mode
Utilizzare la versione generica di EntityTypeConfiguration in Entity Framework Core
Ottenere il contenuto di una cartella FTP con la libreria FluentFTP
Utilizzare database e servizi con gli add-on di Container App