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

【EF学习笔记07】----------加载关联表的数据 贪婪加载

时间:2016-08-09 12:14:30      阅读:554      评论:0      收藏:0      [点我收藏+]

标签:

讲解之前,先来看一下我们的数据库结构:班级表 学生表

技术分享

贪婪加载

//贪婪加载 
using (var db = new Entities())
{
    var classes = db.Classes.Where(v => v.ClassName == "机电10502").Include(v => v.Student);
    foreach (var cls in classes)
    {
        Console.WriteLine("============"+cls.ClassName);
        foreach (var stu in cls.Student)
        {
            Console.WriteLine(stu.StudentName);
        }
    }
}
//使用Include方法 只有一条sql语句被发送到数据库

追踪SQL语句

技术分享

说明:此处根据条件查询,执行了一条SQL,一次性加载班级和该班级的所有学生

该SQL语句执行结果如下:

技术分享

技术分享

遍历所有班级和学生:

using (var db = new Entities())
{
    var classes = db.Classes.Include(v => v.Student);
    foreach (var cls in classes)
    {
        Console.WriteLine("============"+cls.ClassName);
        foreach (var stu in cls.Student)
        {
            Console.WriteLine(stu.StudentName);
        }
    }
}

同样只执行一条SQL语句,结果如下:

技术分享

 

【EF学习笔记07】----------加载关联表的数据 贪婪加载

标签:

原文地址:http://www.cnblogs.com/gosky/p/5752641.html

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