Entity Framework 4 Только код Получить имя таблицы из метаданных для объекта домена POCO - PullRequest
4 голосов
/ 28 сентября 2010

Привет! Я использую код Entity Framework только из CTP4. Мой вопрос заключается в следующем: учитывая имя класса домена, который отображается с помощью EntityConfiguration, как я могу получить имя таблицы для сопоставленного класса во время выполнения? Я предполагаю, что мне нужно использовать MetadataWorkspace в ObjectContext, но мне сложно получить актуальную документацию. Любая помощь или ссылки будут высоко ценится. Спасибо.

1 Ответ

1 голос
/ 30 января 2013

Да, вы правы, всю картографическую информацию можно получить через MetadataWorkspace.

Ниже приведен код для списания имен таблиц и схем для Product класса:

public class Product
{
    public Guid Id { get; set; }
    public string Name { get; set; }
}

public class ProductConfiguration : EntityTypeConfiguration<Product>
{
    public ProductConfiguration()
    {
        HasKey(e => e.Id);

        Property(e => e.Id)
            .HasColumnName(typeof(Product).Name + "Id");

        Map(m =>
        {
            m.MapInheritedProperties();
            m.ToTable("ProductsTable");
        });

        Property(p => p.Name)
            .IsRequired()
            .IsUnicode();
    }
}

public class Database : DbContext
{
    protected override void OnModelCreating(DbModelBuilder modelBuilder)
    {
        modelBuilder.Configurations.Add(new ProductConfiguration());
    }

    public DbSet<Product> Products { get; set; }
}

Теперь, чтобы получить имя таблицы для класса Product, вам нужно создать DbContext и использовать следующий код:

using(var dbContext = new Database())
{
    var adapter = ((IObjectContextAdapter)dbContext).ObjectContext;
    StoreItemCollection storageModel = (StoreItemCollection)adapter.MetadataWorkspace.GetItemCollection(DataSpace.SSpace);
    var containers = storageModel.GetItems<EntityContainer>();

    EntitySetBase productEntitySetBase = containers.SelectMany(c => c.BaseEntitySets.Where(bes => bes.Name == typeof(Product).Name)).First();

    // Here are variables that will hold table and schema name
    string tableName = productEntitySetBase.MetadataProperties.First(p => p.Name == "Table").Value.ToString();
    string schemaName = productEntitySetBase.MetadataProperties.First(p => p.Name == "Schema").
}

Я сомневаюсь, что это идеальное решение, но, как я использовал его раньше, и оно работало без проблем.

...