码迷,mamicode.com
首页 > 其他好文 > 详细

学习EF之贪懒加载和延迟加载(2)

时间:2016-09-30 18:05:36      阅读:130      评论:0      收藏:0      [点我收藏+]

标签:

通过昨天对EF贪婪加载和延迟加载的学习,不难发现,延迟加载还是很好用的,但是问题也就来了,有的时候我们只需要加载一个实体,不需要和他相关的外部实体,这时候我们来看看EF延迟加载时怎么作用的吧

打开profiler

在Main函数入口处写一个查询,在Console.Read();处打一个断点

      static void Main(string[] args)
        {
            var context = new EFDbContext();
            var user = context.Users.FirstOrDefault(a => a.Id == 1);
            Console.WriteLine(user.Name);
            Console.Read();
        }

 

在profiler中最后一行可以看他EF生成sql语句

技术分享

也就是说我们只需要实体本身的属性的时候EF不会帮我们加载外部实体

接下来修改一下Main函数中的内容

      static void Main(string[] args)
        {
            var context = new EFDbContext();
            var users = context.Users.FirstOrDefault(a => a.Id == 1);
            //var users = context.Users.Include("Articles").FirstOrDefault(a => a.Id == 1);
            Console.WriteLine(users.Name);
            foreach (var a in users.Articles)
            {
                Console.WriteLine(a.Title + "," + a.Category.Name + "\n");
            }
            Console.WriteLine(users.Articles.Count() + "\n" + users.Categories.Count() + "\n");
            Console.Read();
        }

 

进行单步调试并观察profiler发现,延迟加载是在我们需要某一个外部实体时才从数据库中查找的

技术分享

换成贪懒加载

技术分享

 结论;

延迟加载是在我们需要的时候才去加载,当需要加载大量的外键对象时会增加与数据库的读取次数

此时可以考虑贪婪加载

 

 

学习EF之贪懒加载和延迟加载(2)

标签:

原文地址:http://www.cnblogs.com/cheesebar/p/5924351.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!