gpt4 book ai didi

c# - 在 CTP4 Code First EF4 功能中查询后导航属性为空

转载 作者:太空宇宙 更新时间:2023-11-03 17:28:22 27 4
gpt4 key购买 nike

我刚刚开始使用 CTP4 和 Code-First。我对可能的约会网站进行了以下设置:

public class User
{
[Key]
public int Id { get; set; }
[Required]
public string LoginName { get; set; }
[Required]
public string Firstname { get; set; }
[Required]
public string Lastname { get; set; }

public string Street { get; set; }
[Required]
public string Zip { get; set; }
[Required]
public string City { get; set; }
[Required]
public bool Gender { get; set; }
[Required]
public int SoughtGender { get; set; }
[Required]
public string Password { get; set; }
[Required]
public double Latitude { get; set; }
[Required]
public double Longitude { get; set; }
}

public class Vote
{
[Key]
public int ID { get; set; }
[Required]
public User Voter { get; set; }
[Required]
public User TargetUser { get; set; }
[Required]
public int Decision { get; set; }
[Required]
public DateTime Timestamp { get; set; }
}

public class MySQLContext : DbContext
{
public MySQLContext (string constring)
: base(constring)
{ }

public DbSet<User> Users { get; set; }
public DbSet<Vote> Votes { get; set; }

protected override void OnModelCreating(System.Data.Entity.ModelConfiguration.ModelBuilder modelBuilder)
{
modelBuilder.Entity<Vote>().HasRequired(b => b.Voter).WithMany();
modelBuilder.Entity<Vote>().HasRequired(b => b.TargetUser).WithMany();
base.OnModelCreating(modelBuilder);

}
}

现在框架可以很好地创建具有所有正确键的数据库。现在我插入了一些虚拟数据并启动了以下查询:

public override IEnumerable<Domain.Vote> FindVotes(Domain.User user)
{
var query = from v in context.Votes where v.Voter.Id == user.Id select v;
return from v in query.AsEnumerable() select v;
}

查询确实返回了正确的 Vote 实体,但 Vote 对象的两个 User 属性为 Null。框架不应该使用投票表中引用的用户的外键填充这些属性吗?

最佳答案

让我向您介绍一些 EF 的背景知识,以便您了解其工作原理。从第 1 天开始,EF 仅支持如下所示的显式加载

Customer.Orders.Load();

嗯,社区不欢迎反馈,开发人员希望延迟加载。为了支持延迟加载,EF 团队表示您必须将导航属性标记为虚拟。因此在运行时,Ef 创建一个代理对象,该对象派生自您的实体并覆盖虚拟属性。下面是此类代码的示例。

public class Customer
{
public string Name{get;set;}
public virtual ICollection<Order> Orders{get;set;}
}

在运行时,有一个实现 IEntityWithChangeTracker 的代理,集合的具体类型是从版本 1 开始就存在的实体集合。

public class CustomerProxy:Customer,IEntityWithChangeTracker
{
private ICollection<Order> orders;
public override ICollection<Order> Orders
{
if(orders == null)
{
orders = new EntityCollection<Order>();
orders.Load();
}
return orders;
}
}

关于c# - 在 CTP4 Code First EF4 功能中查询后导航属性为空,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3458521/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com