How to force Entity Framework to map `internal` navigation properties?(如何强制Entity Frame映射`Intrald`导航属性?)
本文介绍了如何强制Entity Frame映射`Intrald`导航属性?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
使用Code First
与EF 5.0
我有以下几点:
internal class Entities : DbContext
{
public DbSet<User> Users { get; set; }
public DbSet<Project> Projects { get; set; }
}
// User class which holds a list of 'Project' class
public class User
{
private List<Project> _projects = new List<Project>();
public int Id { get; set; }
internal List<Project> Projects
{
get { return _projects; }
set { _projects = value; }
}
}
// Project class which holds a list of 'Milestone' class
public class Project
{
private List<Milestone> _milestones = new List<Milestone>();
public int Id { get; set; }
public string Title { get; set; }
internal List<Milestone> MileStones
{
get { return _milestones; }
set { _milestones = value; }
}
}
尽管EF已经正确地创建了表和关系(一对多For:User=>Project=>Milmark),但如果我创建了一个具有一些项目的用户并将其添加到DbContext
,则只会将该用户添加到,而不会添加到他的项目中。对于具有里程碑的项目的用户也是如此。我是这样做的:
public void AddUser(User user)
{
using (var repository = new Entities())
{
repository.Users.Add(user);
repository.SaveChanges();
}
}
我的问题是如何强制EF
自动插入或更新复杂实体(级联),从而添加一个具有项目列表的用户,自动将该用户插入USERS表中,并将其项目插入PROJECTS表中(关系正确)?
第5版EF
那么智能吗?还是我应该手动完成?
推荐答案
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
modelBuilder.Entity<User>().HasMany(x => x.Projects);
}
这篇关于如何强制Entity Frame映射`Intrald`导航属性?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:如何强制Entity Frame映射`Intrald`导航属性?


猜你喜欢
- WebMatrix WebSecurity PasswordSalt 2022-01-01
- Web Api 中的 Swagger .netcore 3.1,使用 swagger UI 设置日期时间格式 2022-01-01
- 良好实践:如何重用 .csproj 和 .sln 文件来为 CI 创建 2022-01-01
- C# 中多线程网络服务器的模式 2022-01-01
- C#MongoDB使用Builders查找派生对象 2022-09-04
- 输入按键事件处理程序 2022-01-01
- 在哪里可以找到使用中的C#/XML文档注释的好例子? 2022-01-01
- MoreLinq maxBy vs LINQ max + where 2022-01-01
- 如何用自己压缩一个 IEnumerable 2022-01-01
- 带有服务/守护程序应用程序的 Microsoft Graph CSharp SDK 和 OneDrive for Business - 配额方面返回 null 2022-01-01