Browse Source

Skip repeated database migration and unify MigrateHostDatabaseAsync and MigrateTenantDatabasesAsync methods

pull/3683/head
liangshiwei 6 years ago
parent
commit
3db12e6a4d
  1. 42
      templates/app/aspnet-core/src/MyCompanyName.MyProjectName.Domain/Data/MyProjectNameDbMigrationService.cs

42
templates/app/aspnet-core/src/MyCompanyName.MyProjectName.Domain/Data/MyProjectNameDbMigrationService.cs

@ -37,51 +37,45 @@ namespace MyCompanyName.MyProjectName.Data
{
Logger.LogInformation("Started database migrations...");
await MigrateHostDatabaseAsync();
await MigrateDatabaseAsync();
var tenants = await _tenantRepository.GetListAsync(includeDetails: true);
var i = 0;
var migratedDatabases = new HashSet<string>();
foreach (var tenant in tenants.Where(t => t.ConnectionStrings.Any()))
{
using (_currentTenant.Change(tenant.Id))
var tenantConnectionStrings = tenant.ConnectionStrings.Select(x => x.Value).ToList();
if (!migratedDatabases.Any() || !migratedDatabases.IsSupersetOf(tenantConnectionStrings))
{
Logger.LogInformation($"Migrating {tenant.Name} database schema... ({++i} of {tenants.Count})");
await MigrateTenantDatabasesAsync(tenant);
Logger.LogInformation($"Successfully completed {tenant.Name} database migrations.");
using (_currentTenant.Change(tenant.Id))
{
await MigrateDatabaseAsync(tenant);
}
tenantConnectionStrings.ForEach(x => migratedDatabases.Add(x));
}
}
Logger.LogInformation("Successfully completed database migrations.");
}
private async Task MigrateHostDatabaseAsync()
private async Task MigrateDatabaseAsync(Tenant tenant = null)
{
Logger.LogInformation("Migrating host database schema...");
var migrateName = tenant == null ? "host" : tenant.Name + " tenant";
Logger.LogInformation($"Migrating schema for {migrateName} database...");
foreach (var migrator in _dbSchemaMigrators)
{
await migrator.MigrateAsync();
}
Logger.LogInformation("Executing host database seed...");
await _dataSeeder.SeedAsync();
Logger.LogInformation("Successfully completed host database migrations.");
}
private async Task MigrateTenantDatabasesAsync(Tenant tenant)
{
Logger.LogInformation($"Migrating schema for {tenant.Name} database...");
Logger.LogInformation($"Executing {migrateName} database seed...");
foreach (var migrator in _dbSchemaMigrators)
{
await migrator.MigrateAsync();
}
await _dataSeeder.SeedAsync(tenant?.Id);
Logger.LogInformation($"Executing {tenant.Name} tenant database seed...");
await _dataSeeder.SeedAsync(tenant.Id);
Logger.LogInformation($"Successfully completed {migrateName} database migrations.");
}
}
}
Loading…
Cancel
Save