0到与EF Code First的一个关联

时间:2015-01-16 15:23:04

标签: c# entity-framework c#-4.0 ef-code-first

我有一个现有的数据库,想要使用Fcode API的EF Code First将我的实体映射到数据库中的表。

我的表是:

Bank(KeyB,BankName) - KeyB是PrimaryKey

User(KeyU,UserName,KeyB) - KeyU是PrimaryKey,KeyB有一个外键,可以为null。

我有这些实体:

class Bank
{
    public int Id;
    public string Name;
}

class User
{
    public int KeyU;
    public Bank Bank;
}

我无法让我的0到1协会使用流畅的API。 我尝试在User实体中添加一个可以为空的int属性BankId(如果可能的话,我希望能够避免这种情况)并将以下代码添加到映射中,但没有运气:

class UserMap:EntityTypeConfiguration<User>
{
    public UserMap()
    {
        this.HasKey(u => u.KeyU);
        this.Property(u => u.BankId).HasColumnName("KeyB");
        this.HasOptional(u => u.Bank).WithMany().HasForeignKey(u => u.BankId);
    }
}

User实例中的Bank属性始终为null。

您对如何实现这一目标有任何想法吗?

[UPDATE] 我现在有以下代码仍然不起作用:

    class TestCFContext:DbContext
    {
        public TestCFContext():base(ConnectionString())
        {}
        private static string ConnectionString()
        {return "Data Source=.;Initial Catalog=Test;Integrated Security=SSPI;";}
        public DbSet<User> Users { get; set; }
        protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            modelBuilder.Configurations.Add(new UserMap());
            modelBuilder.Configurations.Add(new BankMap());
        }
    }
    class UserMap:EntityTypeConfiguration<User>
    {
        public UserMap()
        {
            this.HasKey(u => u.Id);
            this.Property(u => u.Id).HasColumnName("KeyU");
            this.HasOptional(u => u.Bank).WithMany().Map(c => c.MapKey("KeyB"));
            this.ToTable("Users");
        }
    }
    class BankMap:EntityTypeConfiguration<Bank>
    {
        public BankMap()
        {
            this.HasKey(b => b.Id);
            this.Property(b => b.Id).HasColumnName("KeyB");
            this.ToTable("Banks");
        }
    }

 class Bank
    {
        public int Id { get; set; }
        public string Name { get; set; }
    }

    class User
    {
        public int Id { get; set; }
        public string Name { get; set; }
        public virtual Bank Bank { get; set; }
    }

       static void Main(string[] args)
        {
            var c = new TestCFContext();
            foreach (var u in c.Users)
            {
                Console.WriteLine(u.Bank.Id);
            }

}

1 个答案:

答案 0 :(得分:0)

导航属性User.Bank必须是虚拟的,实体本身必须是公共的,否则 Entity Framework 无法链接Bank对象。 (从技术上讲,它创建了一个继承实体的动态类,以确保工作导航属性......)

public class Bank
{
    public int KeyB { get; set; }
    public string BankName { get; set; }
}

public class User
{
    public int KeyU { get; set; }
    public string UserName { get; set; }
    public virtual Bank Bank { get; set; }
}

使用这些映射,您应该能够检索银行(如果有)。

public class BankMap : EntityTypeConfiguration<Bank>
{
    public BankMap()
    {
        this.HasKey(b => b.KeyB);
    }
}

public class UserMap : EntityTypeConfiguration<User>
{
    public UserMap()
    {
        this.HasKey(u => u.KeyU);
        this.HasOptional(u => u.Bank)
            .WithMany()
            .Map(c => c.MapKey("KeyB"));
    }
}

我使用当前的EF版本(6.1.2)进行了测试。