Oracle
 sql >> Datenbank >  >> RDS >> Oracle

Entity Framework und mehrere Schemas

Bei meiner Recherche zu Entity Framework bin ich auf folgenden Beitrag gestoßen:

http://romiller.com/2011/05/23/ef-4-1-multi-tenant-with-code-first/

Es gibt mir nicht ganz einen einzigen dbContext, mit dem ich arbeiten kann, aber es verwendet nur eine einzige Verbindung (was meine Begründung dafür war, nicht mehrere dbContexts verwenden zu wollen). Nach dem Einrichten des folgenden Codes:

public class oraDbContext : DbContext
{
    static oraDbContext() {
        Database.SetInitializer<oraDbContext>(null);
    }

    private oraDbContext(DbConnection connection, DbCompiledModel model)
        : base(connection, model, contextOwnsConnection: false) { }

    public DbSet<SomeTable1> SomeTable1 { get; set; }
    public DbSet<SomeTable2> SomeTable2 { get; set; }

    private static ConcurrentDictionary<Tuple<string, string>, DbCompiledModel> modelCache = new ConcurrentDictionary<Tuple<string, string>, DbCompiledModel>();

    public static oraDbContext Create(string schemaName, DbConnection connection) {
        var compiledModel = modelCache.GetOrAdd(
            Tuple.Create(connection.ConnectionString, schemaName),
            t =>
            {
                var builder = new DbModelBuilder();
                builder.Configurations.Add<SomeTable1>(new SomeTable1Map(schemaName));
                builder.Configurations.Add<SomeTable2>(new SomeTable2Map(schemaName));

                var model = builder.Build(connection);
                return model.Compile();
            });

        return new oraDbContext(connection, compiledModel);
    }
}

Dies erfordert natürlich, dass meine Mapping-Dateien wie folgt eingerichtet sind:

public class DailyDependencyTableMap : EntityTypeConfiguration<DailyDependencyTable>
{
    public SomeTableMap(string schemaName) {
        this.ToTable("SOME_TABLE_1", schemaName.ToUpper());

        //Map other properties and stuff
    }
}

Das Schreiben von Abfragen, die mehrere Schemata verwenden, ist etwas lästig, aber im Moment tut es das, wofür ich es brauche:

using (var connection = new OracleConnection("a connection string")) {
    using (var schema1 = oraDbContext.Create("SCHEMA1", connection))
    using (var schema2 = oraDbContext.Create("SCHEMA2", connection)) {

        var query = ((from a in schema1.SomeTable1 select new { a.Field1 }).ToList())
             .Concat((from b in schema2.SomeTable1 select new { b.Field1 }).ToList())
    }
}