EntityFramework延迟加载

php中文网
发布: 2016-06-07 16:12:38
原创
1350人浏览过

延迟加载:即当我们需要用到的时候才进行加载(读取) 当我们希望浏览某条订单信息的时候,才显示其对应的订单详细记录时,我们希望使用延迟加载来实现,这样不仅加快的了读取的效率,同时也避免加载不需要的数据。延迟加载通常用于foreach循环读取数据时。

延迟加载:即当我们需要用到的时候才进行加载(读取)

延迟加载图片插件Lazy Load XT
延迟加载图片插件Lazy Load XT

延迟加载图片插件Lazy Load XT

延迟加载图片插件Lazy Load XT 21
查看详情 延迟加载图片插件Lazy Load XT

当我们希望浏览某条订单信息的时候,才显示其对应的订单详细记录时,我们希望使用延迟加载来实现,这样不仅加快的了读取的效率,同时也避免加载不需要的数据。延迟加载通常用于foreach循环读取数据时。

EF中支持延迟加载,是因为 进行查询,返回DbQuery类

\

为了展示延迟加载,所以 使用 sql server profiler 进行查看 数据的查询。

Sql server profiler 用于监视 sql的连接执行情况。建立一个新的跟踪。

\

当我们使用DbContext类对EF进行操作时候:

\

已经执行完查询了,但是 查询跟踪器里面为空:

\

只有在使用查询结果的时候,EF才会去执行sql语句。

D╧y数据库。其实,就是要想对数据库进行操作 直接 对实体 就行操作就行了。

更符合面向对象的思想了。

直接加载的思想:

1、声明变量

2、要查询的条件

3、根据查询条件 去查询 然后 把结果存放在变量中

用的时候,直接把变量拿过来用

延迟加载的思想:

1、声明变量

2、输入要查询的条件

用的时候,把变量和条件 都拿过来,执行完后 在用

两种思想,分别处理不同的情况。就和 真假分页 是一个道理。

1、如果是在foreach循环中加载数据,那么使用延迟加载会比较好,因为不需要一次性将所有数据读取出来,这样虽然有可能会造成n次数据库的查询,但是基本上在可以接受的范围内。

2、如果在开发时就可以预见需要一次性加载所有的数据,包含关联表的所有数据,那么使用使用贪婪加载是比较好的选择,但是此种方式会导致效率问题,特别是数据量大的情况下。

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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