Quando sviluppiamo applicazioni multitenant ci troviamo sempre davanti a una scelta: utilizzare un solo database per tutti i tenant o utilizzare un database per tenant? Nel caso optassimo per la seconda scelta, dovremmo impostare la stringa di connessione in base all'utente. A partire da Entity Framework Core 5, possiamo modificare la stringa di connessione, anche una volta che il contesto è stato inizializzato, attraverso l'extension method SetConnectionString della classe DatabaseFacade esposta dalla proprietà Database del contesto.
static void Main(string[] args)
{
using (var ctx = new NorthwindContext())
{
var x1 = ctx.Customers.ToList();
ctx.Database.SetConnectionString("newconnectionstring");
var x2 = ctx.Customers.ToList();
In questo esempio, la prima query viene eseguita usando la stringa di connessione impostata in configurazione, mentre la seconda viene eseguita usando la nuova stringa di connessione.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Integrare LLM alle nostre applicazioni in .NET con MCP
Eseguire query in contemporanea con EF
Definire il metodo di rilascio in .NET Aspire
Esporre un server MCP esistente con Azure API Management
Utilizzare Containers in .NET Aspire
Utilizzare Locust con Azure Load Testing
Simulare Azure Cosmos DB in locale con Docker
Utilizzare i command service nei test con .NET Aspire
Esporre tool MCP con Azure Functions
Abilitare il rolling update su Azure Functions flex consumption
Disabilitare le run concorrenti di una pipeline di Azure DevOps
Semplificare i deployment con le label in Azure Container App


