在C#的Entity Framework(EF)中,延时加载(Lazy Loading)是一种对象关系映射(ORM)特性,它允许在需要时自动加载相关实体。当访问导航属性(即一个实体类中引用另一个实体类的属性)且该实体尚未从数据库加载时,延时加载机制会自动执行SQL查询以获取相关的实体数据。
在Entity Framework Core中,延时加载功能默认是关闭的。若要启用延时加载,需满足以下条件:
Microsoft.EntityFrameworkCore.DbContext
,并且包含虚拟导航属性。例如: public class Blog
{
public int BlogId { get; set; }
public string Name { get; set; }
// 虚拟导航属性实现延迟加载
public virtual ICollection Posts { get; set; }
}
UseLazyLoadingProxies()
方法在DbContextOptions中启用代理生成,这是实现延时加载所必需的。通常在Startup.cs或DbContext构造函数中进行配置: services.AddDbContext(options =>
options.UseSqlServer(Configuration.GetConnectionString("DefaultConnection"))
.UseLazyLoadingProxies());
Blog.Posts
属性时,如果Posts尚未加载,则会在背后触发数据库查询以加载所有关联的Post实体。请注意,在EF6及更早版本中,延时加载的行为有所不同,但同样需要导航属性为虚拟属性才能启用延时加载。
另外,除了延时加载,还有两种常见的加载策略:
.Include()
方法来一次性加载关联的数据。Load()
方法来加载关联实体。延时加载虽然方便,但在某些性能敏感场景下可能不是最佳选择,因为它可能导致多次数据库查询,并且可能会无意中加载大量额外数据。因此,在设计应用程序时应根据实际需求合理选择合适的加载策略。