我有一个现有的数据库,想要使用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);
}
}
答案 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)进行了测试。