与实体框架中的POCO类的多对多关系(DB优先)

时间:2013-01-16 12:52:17

标签: entity-framework many-to-many poco

我的上下文看起来像这样:

public DbSet<User> Users { get; set; }
public DbSet<AccessGroup> AccessGroups { get; set; }
public DbSet<UserAccessGroup> UsersAccessGroups { get; set; }

数据库有三个表:

  • 用户[Pk = Id,...]
  • AccessGroups [Pk = Id,...]
  • UsersAccessGroups [Pk = Id,Fk = UserId,Fk = AccessGroupId,...](具有由以及何时创建的列)

我们有三个班级:

public class User
{
  public virtual int Id { get; set; }
  public virtual ICollection<UserAccessGroup> UsersAccessGroups { get; set; }
  // Some more..
}

public class AccessGroup
{
  public virtual int Id { get; set; }
  public virtual ICollection<UserAccessGroup> UsersAccessGroups { get; set; }
  // Some more..
}

[Table("UsersAccessGroups")]
public class UserAccessGroup
{
  public virtual int Id { get; set; }
  public virtual int UserId { get; set; }
  public virtual int AccessGroupId { get; set; }
  public virtual int CreatedByUserId { get; set; }
  public virtual DateTime CreatedAt { get; set; }

  public virtual User User { get; set; }
  public virtual AccessGroup AccessGroup { get; set; }
  public virtual User CreatedByUser { get; set; }
}

我希望能够使用这样的用户对象:

var user = Context.Users.Select(x => x);
var accessGroup = user.UsersAccessGroups.Select(x => x.AccessGroup).ToList();

但是第二行不起作用。我收到错误消息“无效的列名User_Id” 当我有一对一的关系(比如CreatedByUser)时,相同的代码就可以工作。

我也尝试过这样的事情:

Context.Users.Include("UsersAccessGroups")
  .Include("UsersAccessGroups.AccessGroup")
  .Include("UsersAccessGroups.User").Select(...);

但是我遇到了同样的问题。

是否有可能让这个工作,或者我必须以某种方式做不同的事情?

1 个答案:

答案 0 :(得分:0)

您需要为CreatedByUser指定外键,因为EF无法按惯例映射。

[Table("UsersAccessGroups")]
public class UserAccessGroup
{
  public virtual int Id { get; set; }
  public virtual int UserId { get; set; }
  public virtual int AccessGroupId { get; set; }
  public virtual int CreatedByUserId { get; set; }
  public virtual DateTime CreatedAt { get; set; }

  public virtual User User { get; set; }
  public virtual AccessGroup AccessGroup { get; set; }
  [ForeignKey("CreatedByUserId")]
  public virtual User CreatedByUser { get; set; }
}
相关问题