0

0

.NET 中的延迟加载模式在 EF Core 中的应用?

小老鼠

小老鼠

发布时间:2025-10-07 13:06:01

|

195人浏览过

|

来源于php中文网

原创

答案:EF Core中延迟加载需安装Microsoft.EntityFrameworkCore.Proxies包并配置UseLazyLoadingProxies,实体导航属性标记为virtual,访问时触发查询,但易引发N+1问题,建议生产环境使用Include或显式加载替代。

.net 中的延迟加载模式在 ef core 中的应用?

在 EF Core 中,延迟加载(Lazy Loading)是一种数据加载策略,它允许你在访问导航属性时才从数据库中加载相关数据,而不是在查询主实体时立即加载。这种模式可以减少初始查询的数据量,提升性能,但需要小心使用以避免“N+1 查询”问题。

启用延迟加载的条件

EF Core 默认不开启延迟加载,要使用该功能,需满足以下条件之一:

  • 实体中的导航属性必须标记为 virtual,以便支持运行时动态代理
  • 安装并启用 Microsoft.EntityFrameworkCore.Proxies
  • DbContext 配置中启用延迟加载代理
例如,通过 NuGet 安装代理包:
Install-Package Microsoft.EntityFrameworkCore.Proxies

然后在 OnConfiguringStartup.cs 中配置上下文:

protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
    optionsBuilder
        .UseLazyLoadingProxies() // 启用延迟加载代理
        .UseSqlServer("YourConnectionString");
}

实体定义示例

以下是一个简单的父子关系模型,展示如何定义支持延迟加载的实体:

public class Blog
{
    public int Id { get; set; }
    public string Name { get; set; }

    public virtual ICollection Posts { get; set; } // virtual 启用延迟加载
}

public class Post
{
    public int Id { get; set; }
    public string Title { get; set; }
    public int BlogId { get; set; }

    public virtual Blog Blog { get; set; } // 导航属性也应为 virtual
}

当你查询 Blog 时,Posts 不会立即加载:

天龙企业网站管理系统 2008.net
天龙企业网站管理系统 2008.net

天龙企业网站管理系统,基于.net2.0+access开发,系统架构采用MVC设计模式,是一个十分优秀的.net企业管理系统。其中包括产品发布,新闻发布,企业简价,企业文化,下载中心,客户留言等功能。在V2.0 sp2 基础上再次升级: 1、修正了前台的投票调查功能。 2、增强系统安全性,增加了防SQL注入功能 3、修补了后台漏洞 4、增加了前台游客留言的字符过滤,自动过滤html格式以增强系统安

下载
var blog = context.Blogs.FirstOrDefault(b => b.Id == 1);
// 此时 Posts 为空,尚未查询数据库

var posts = blog.Posts; // 访问时才会触发数据库查询

延迟加载的注意事项

虽然延迟加载简化了代码,但也带来一些潜在问题:

  • 容易引发 N+1 查询:循环访问多个博客的帖子时,可能产生大量数据库往返
  • 必须保持 DbContext 在访问导航属性时仍然存活
  • 序列化对象时可能意外触发加载,导致性能下降或循环引用错误
  • 动态代理可能与某些第三方库或自定义构造函数冲突

在 Web 应用中,若在 Controller 外部访问导航属性(如视图或 API 响应序列化),需确保上下文生命周期足够长,或改用显式加载(Load())或预先加载(Include())。

替代方案建议

在多数生产场景中,推荐结合使用以下方式代替纯延迟加载:

  • Include():使用 Eager Loading 显式加载所需关联数据
  • Select():投影出所需字段,减少数据传输
  • Explicit Loading:手动调用 Entry().Collection().Load() 控制加载时机

基本上就这些。延迟加载适合快速原型或简单场景,但在性能敏感或复杂应用中,建议更精确地控制数据加载行为。

相关专题

更多
数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

352

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2076

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

347

2023.08.31

MySQL恢复数据库
MySQL恢复数据库

MySQL恢复数据库的方法有使用物理备份恢复、使用逻辑备份恢复、使用二进制日志恢复和使用数据库复制进行恢复等。本专题为大家提供MySQL数据库相关的文章、下载、课程内容,供大家免费下载体验。

255

2023.09.05

vb中怎么连接access数据库
vb中怎么连接access数据库

vb中连接access数据库的步骤包括引用必要的命名空间、创建连接字符串、创建连接对象、打开连接、执行SQL语句和关闭连接。本专题为大家提供连接access数据库相关的文章、下载、课程内容,供大家免费下载体验。

324

2023.10.09

数据库对象名无效怎么解决
数据库对象名无效怎么解决

数据库对象名无效解决办法:1、检查使用的对象名是否正确,确保没有拼写错误;2、检查数据库中是否已存在具有相同名称的对象,如果是,请更改对象名为一个不同的名称,然后重新创建;3、确保在连接数据库时使用了正确的用户名、密码和数据库名称;4、尝试重启数据库服务,然后再次尝试创建或使用对象;5、尝试更新驱动程序,然后再次尝试创建或使用对象。

410

2023.10.16

vb连接access数据库的方法
vb连接access数据库的方法

vb连接access数据库方法:1、使用ADO连接,首先导入System.Data.OleDb模块,然后定义一个连接字符串,接着创建一个OleDbConnection对象并使用Open() 方法打开连接;2、使用DAO连接,首先导入 Microsoft.Jet.OLEDB模块,然后定义一个连接字符串,接着创建一个JetConnection对象并使用Open()方法打开连接即可。

405

2023.10.16

vb连接数据库的方法
vb连接数据库的方法

vb连接数据库的方法有使用ADO对象库、使用OLEDB数据提供程序、使用ODBC数据源等。详细介绍:1、使用ADO对象库方法,ADO是一种用于访问数据库的COM组件,可以通过ADO连接数据库并执行SQL语句。可以使用ADODB.Connection对象来建立与数据库的连接,然后使用ADODB.Recordset对象来执行查询和操作数据;2、使用OLEDB数据提供程序方法等等。

221

2023.10.19

菜鸟裹裹入口以及教程汇总
菜鸟裹裹入口以及教程汇总

本专题整合了菜鸟裹裹入口地址及教程分享,阅读专题下面的文章了解更多详细内容。

0

2026.01.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 7.3万人学习

ASP教程
ASP教程

共36课时 | 22.7万人学习

李炎恢ASP基础视频教程
李炎恢ASP基础视频教程

共210课时 | 43.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号