5.5.1 《关于“数据关联”,你不一定清楚的事》

这讲视频比较全面地介绍了“一对一”、“一对多”和“多对多”三种数据关联类型在关系数据库和Entity Framework数据模型中的实现。再次强调一下,本讲所介绍的内容非常重要,务必掌握。

5.5.2 《Entity Framework与单元测试》 

在数据库应用程序开发中,单元测试对保证代码质量,实现敏捷开发具有重要意义,在这讲视频中,将向您介绍一些实用的单元测试方法,这些方法,您可以直接应用于自己的项目开发实践中。另外,在后继的视频中,我们也会使用单元测试这个工具来探索Entity Framework的技术内幕。

提示一下,请注意如何对异步方法进行单元测试

5.5.3 《关联数据的延迟加载》 

默认情况下,Entity Framework会为数据实体类的导航属性添加一个virtual关键字,在程序运行时,这将导致Entity Framework创建一个代理对象,实现“需要时才提取数据”的这一数据提取策略,而这一切全都是自动的。本讲视频通过单元测试示例,介绍了Entity Framework的这一功能特性。

5.5.4 《关联数据的预加载》 

可以使用Include("导航属性名")的方式,让Entity Framework生成一条Join查询语句,一次性地把所有需要的数据都提取出来。本讲视频介绍了Entity Framework的这个特性。

5.5.5 《关联数据的显式加载》 

在代码中可以随时使用Load()方法,在需要的时候加载数据。本讲视频展示了这种数据加载的实例。

在这一课时中,我们将围绕着“数据关联”这个中心而展开。不要轻视“数据关联”这件事,在开发数据库应用程序时,弄清楚哪些数据之间有关联,又如何设计与实现这些关联,都是很要紧的问题,处理不好,会给系统的运行性能、日后的系统维护和二次开发,带来很大的麻烦。

在学习后面的内容之前,请务必保证你已经掌握本课时所介绍的内容。

5.5.1 《关于“数据关联”,你不一定清楚的事》  时长:15分16秒 难度:偏难

这讲视频比较全面地介绍了“一对一”、“一对多”和“多对多”三种数据关联类型在关系数据库和Entity Framework数据模型中的实现。再次强调一下,本讲所介绍的内容非常重要,务必掌握。

5.5.2 《Entity Framework与单元测试》  时长:12分50秒 难度:中

在数据库应用程序开发中,单元测试对保证代码质量,实现敏捷开发具有重要意义,在这讲视频中,将向您介绍一些实用的单元测试方法,这些方法,您可以直接应用于自己的项目开发实践中。另外,在后继的视频中,我们也会使用单元测试这个工具来探索Entity Framework的技术内幕。

提示一下,请注意如何对异步方法进行单元测试

using System;
using Microsoft.VisualStudio.TestTools.UnitTesting;
using whatIsEF;
using System.Linq;
using System.Data.Entity; namespace UnitTestwhatIsEF
{
[TestClass]
public class UnitTest
{
// 用于存储提供给单元测试的信息。
private TestContext testContextInstance; public TestContext TestContextInstance
{
get { return testContextInstance; }
set { testContextInstance = value; }
} //声明一个UPMSEntities
private static UPMSEntities context; //必须在测试类中的任意测试运行之前使用
[ClassInitialize()]
public static void myClassInitialize(TestContext textcontext)
{
//就不用使用 using (UPMSEntities dbc = new UPMSEntities())
context = new UPMSEntities();
} //测试类中所有的测试都运行以后使用
[ClassCleanup()]
public static void MyClassCleanup()
{
//最后销毁
context.Dispose();
} //测试方法
[TestMethod]
public void TestShowUPMS_User()
{
var lq = from d in context.UPMS_User
select d;
Assert.IsTrue(lq.Count() > 0);
foreach (var item in lq)
{
Console.WriteLine(item.UserId + "," + item.RealName);
}
}
}
}

5.5.3 《关联数据的延迟加载》  时长:7分51秒  难度:偏难

默认情况下,Entity Framework会为数据实体类的导航属性添加一个virtual关键字,在程序运行时,这将导致Entity Framework创建一个代理对象,实现“需要时才提取数据”的这一数据提取策略,而这一切全都是自动的。本讲视频通过单元测试示例,介绍了Entity Framework的这一功能特性。

*EF上下文里的 DBSet<T> 里的标准查询运算符方法,来自于System.Linq.Queryable里 给IQueryable接口添加的方法
*延迟加载,本质原因一: 当前可能通过多个SQO方法来组合 查询条件,那么每个方法 都只是添加一个查询条件而已,
* 无法确定本次查询条件是否已经添加结束
* 所以,没有办法在每个SQO方法的时候确定SQL语句是什么,只能返回一个包含了所有添加条件的 DbQuery对象
* 当使用这个 DbQuery对象 的时候,才根据所有条件生成 SQL 语句,查询数据库

5.5.4 《关联数据的预加载》  时长:3分41秒 难度:中

可以使用Include("导航属性名")的方式,让Entity Framework生成一条Join查询语句,一次性地把所有需要的数据都提取出来。本讲视频介绍了Entity Framework的这个特性。

5.5.5 《关联数据的显式加载》  时长:5分23秒 难度:偏难

在代码中可以随时使用Load()方法,在需要的时候加载数据。本讲视频展示了这种数据加载的实例。

金旭亮

面向对象软件开发实践之专业技能训练

MOOC课程 http://mooc.study.163.com/learn/BIT-1000013000#/learn/content?type=detail&id=1000166069

EF – 3.EF数据查询基础(下)数据关联的更多相关文章

  1. 深入理解 EF Core:使用查询过滤器实现数据软删除

    原文:https://bit.ly/2Cy3J5f 作者:Jon P Smith 翻译:王亮 声明:我翻译技术文章不是逐句翻译的,而是根据我自己的理解来表述的.其中可能会去除一些本人实在不知道如何组织 ...

  2. 数据库==&gt;&gt;数据查询基础

    数据查询基础 还好吗?几天不见,甚是思念呀!笑对人生,好好生活,快快乐乐的迎接我们的美好未来吧! 好吧!抒情结束,我们一起来学习一下我们今天的主题:数据查询基础,很有意思哟.让我们来感受它的魅力吧! ...

  3. sql数据查询基础笔记

    使用SELETE语句进行查询 语法 SELECT<列名> FROM<表名>  [ORDER BY <排序的列名>[ASC或DESC]] 1.查询所有的数据和列 SE ...

  4. EF &ndash; 2.EF数据查询基础(上)查询数据的实用编程技巧

    目录 5.4.1 查询符合条件的单条记录 EF使用SingleOrDefault()和Find()两个方法查询符合条件的单条记录. 5.4.2 Entity Framework中的内部数据缓存 DbS ...

  5. EF – 2.EF数据查询基础(上)查询数据的实用编程技巧

    目录 5.4.1 查询符合条件的单条记录 EF使用SingleOrDefault()和Find()两个方法查询符合条件的单条记录. 5.4.2 Entity Framework中的内部数据缓存 DbS ...

  6. HQL数据查询基础

    HQL定义 1.Hibernate Query Language, Hibernate查询语言 2.HQL是面向对象的查询语言(HQL查询的主体是映射配置的持久化类及其属性而SQL查询主体是数据库表) ...

  7. Oracle数据库命令行下数据的导入导出

    //设置导入导出字符集,导入导出都要设置一下 export NLS_LANG=AMERICAN_AMERICA.ZHS16GBK //导出 exp system/oracle@orcl file=/u ...

  8. hibernate的基础学习--多表关联数据查询

    Hibernate共提供4种多表关联数据查询方式 OID数据查询+OGN数据查询方式 HQL数据查询方式 QBC数据查询方式 本地SQL查询方式(hibernate很少用) 1.OID数据查询+OGN ...

  9. CYQ.Data 轻量数据层之路 使用篇二曲 MAction 数据查询(十三)----002

    原文链接:https://blog.csdn.net/cyq1162/article/details/53303390 前言说明: 本篇继续上一篇内容,本节介绍所有相关查询的使用. 主要内容提要: 1 ...

随机推荐

  1. Jquery实现循环删除Reaper某一行

    一.实现的效果图:(点击删除图标,juery实现删除整行) 二.MVC开发模式 SQLServer层 #region 删除 /// <summary> /// 根据自动编号删除快递线路信息 ...

  2. Sublime text3 安装

    Sublime是一款跨平台的前端开发神器,国外的一款共享软件,虽然是未注册的但不影响使用. 一.下载最新版的安装包 官网地址:http://www.sublimetext.com/3 --portab ...

  3. 转 Android adb root权限

    永久root带文件 因为开发需要,我经常会用到adb这个工具(Android Debug Bridge),我们都知道adb shell默认是没有root权限的,修改系统文件就很不方便了,adb pus ...

  4. linux下串口通信与管理

    linux下的串口与windows有一些区别,下面将介绍一下linux下串口通信管理 查看是否支持USB串口: #lsmod | grep usbserial 如果没有信息:sudo apt-get ...

  5. hdu_5727_Necklace(二分匹配)

    题目连接:hdu_5727_Necklace 题意: 有2*n个珠子,n个阳珠子,n个阴珠子,现在要将这2n个珠子做成一个项链,珠子只能阴阳交替排,有些阳珠子周围如果放了指定的阴珠子就会变坏,给你一个 ...

  6. tcpdump常用参数详解

    tcpdump常用参数详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 好久没有更新我的博客了,看来自己最近还没有在放假中回过神来啊,哈哈~是不是也有小伙伴跟我一样呢?回归正题, ...

  7. ALGO-145_蓝桥杯_算法训练_4-1打印下述图形

    记: 这里用到了printf("%*s%s%*s\n",n-i,"",arr,n-i,"");的写法, 其中%*s中的*代表该字符串s的个数 ...

  8. OpenGL 遮挡查询

    原文地址:http://www.linuxidc.com/Linux/2015-02/114036.htm 在一个场景中,如果有有些物体被其他物体遮住了不可见.那么我们就不需要绘制它.在复杂的场景中, ...

  9. 初识HDFS原理及框架

    目录 HDFS是什么 HDFS的优缺点 HDFS的框架 HDFS的读写流程 HDFS命令 HDFS参数 1. HDFS是什么 HDFS(Hadoop Distributed File System)是 ...

  10. Ansible开发之路

    一.初识Ansible 链接:https://www.cnblogs.com/baishuchao/articles/9164083.html 二.Ansible的架构 链接:https://www. ...