假设有多对多关系的两个实体类A和B,则需要先创建一个中间表来维护关系。假设中间表命名为AtoB。
- 在ABP项目中的EntityFrameworkCore项目中,分别在A和B的实体类中添加如下代码:
在类定义上方:
[Table("A")]
public class A : Entity
{
...
[ManyToMany(typeof(AtoB))] // 指定中间表类型
public virtual ICollection Bs { get; set; }
}
在类成员定义上方:
public class AtoB : Entity
{
public virtual A A { get; set; }
public virtual B B { get; set; }
}
- 在ABP项目中的应用层或领域层中,查询数据时需要使用Include方法显式加载导航属性(即Bs),如下所示:
var a = await _aRepository.GetAll()
.Include(a => a.Bs)
.FirstOrDefaultAsync(a => a.Id == id);
这样可以获取到所有与实体A相关联的实体B。
注意:新增或更新数据时也需要手动添加中间表记录,具体方法请参考ABP官方文档。