Entity Framework 四
实体框架支持三种类型的查询:1)LINQ to Entities,2)Entity SQL,3)Native SQL
LINQ方法语法:

LINQ查询语法:

实体SQL: 这种可以简单的了解,不必深入研究,知道LINQ语法或原始SQL查询就可以了。
实体SQL是另一种创建查询的方法。它由实体框架的对象服务直接处理。它返回ObjectQuery而不是IQueryable。
您需要ObjectContext来使用Entity SQL创建一个查询。

原生SQL:

LINQ-to-Entities查询本质就是使用了LINQ查询语法
DbSet类
DBSet类表示用于创建,读取,更新和删除操作的实体集。当构建时不知道实体的类型时,可以使用DBSet(DbSet <TEntity>)的通用版本。
您可以通过使用DBContext获取DBSet的引用,例如。dbcontext.Students等。DbContext类包括DbSet,如下所示:

DBSet类的一些重要方法:







访问MSND获取有关DBSet类的更多信息。
DBEntityEntry类
DBEntityEntry是一个重要的类,在检索有关实体的各种信息时非常有用。您可以使用DBContext的Entry方法获取特定实体的DBEntityEntry实例。例如:

DBEntityEntry使您可以访问给定实体的所有属性的实体状态,当前值和原始值。以下示例代码显示如何检索特定实体的重要信息。

DbEntityEntry使您能够将实体状态添加,修改或删除,如下所示。

DBEntityEntry类具有以下重要的方法:








有关DBEntityEntry类的更多信息,请访问MSDN 。
在实体框架中更改跟踪:
实体框架支持在上下文的生命周期中加载实体的自动更改跟踪。DbChangeTracker类为您提供有关当前正在被上下文跟踪的实体的所有信息。
请注意,每个实体必须具有EntityKey(主键)属性才能被上下文跟踪。实体框架不会在没有EntityKey属性的概念模型中添加任何实体。
例如:
static void Main(string[] args)
{
using (var ctx = new SchoolDBEntities())
{
Console.WriteLine("查找");
var student = ctx.Students.Find();
Console.WriteLine("{0}个实体上下文跟踪情况", ctx.ChangeTracker.Entries().Count());
DisplayTrackedEntities(ctx.ChangeTracker);
Console.WriteLine("查找");
var student1 = ctx.Standards.Find();
Console.WriteLine("{0}个实体上下文跟踪情况", ctx.ChangeTracker.Entries().Count());
Console.WriteLine("编辑");
student1.StandardName = "编辑名称";
DisplayTrackedEntities(ctx.ChangeTracker);
Teacher teacher = new Teacher() { TeacherName = "新老师" };
Console.WriteLine("添加老师");
ctx.Teachers.Add(teacher);
Console.WriteLine("{0}个实体上下文跟踪情况", ctx.ChangeTracker.Entries().Count());
DisplayTrackedEntities(ctx.ChangeTracker);
Console.WriteLine("删除学生");
ctx.Students.Remove(student);
DisplayTrackedEntities(ctx.ChangeTracker);
}
} private static void DisplayTrackedEntities(DbChangeTracker changeTracker)
{
Console.WriteLine("");
var entries = changeTracker.Entries();
foreach (var item in entries)
{
Console.WriteLine("实体名称:{0}", item.Entity.GetType().FullName);
Console.WriteLine("状态:{0}", item.State);
}
Console.WriteLine("");
Console.WriteLine("----------------------------");
}

每当我们检索,添加,修改或删除任何实体时,上下文都会跟踪实体。请注意,在实体的任何操作过程中,上下文都处于活动状态。如果您对范围外的实体进行任何操作,则上下文不会跟踪。
持久化一个实体框架
使用EntityFramework,连接和断开连接的场景来持久化一个实体有两种情况。
连接场景:这是当从数据库中检索实体并在相同的上下文中使用persist时。Context对象不会在实体的实体检索和持久化之间破坏。

断开连接的场景:断开的连接场景是从数据库中检索实体,并使用上下文中的不同对象提交更改的实体。以下示例说明了断开的情况:

根据上述情况,Context1用于读取操作,然后Context1被销毁。一旦实体发生变化,应用程序使用Context2提交实体 - 一个不同的上下文对象。
断开的情况是复杂的,因为新的上下文不知道修改的实体的任何内容,所以你将不得不指示实体中已经改变的上下文。在下图中,应用程序使用上下文1检索实体图,然后应用程序对其执行一些CUD(创建,更新,删除)操作,最后使用上下文2保存实体图。上下文2不知道什么在这种情况下,已经在实体图上执行了操作。
Entity Framework 四的更多相关文章
- 第四篇 Entity Framework Plus 之 Batch Operations
用 Entity Framework 进行 增,删,改.都是基于Model进行的,且Model都是有状态追踪的.这样Entity Framework才能正常增,删,改. 有时候,要根据某个字段,批量 ...
- 《Entity Framework 6 Recipes》中文翻译系列 (20) -----第四章 ASP.NET MVC中使用实体框架之在MVC中构建一个CRUD示例
翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 第四章 ASP.NET MVC中使用实体框架 ASP.NET是一个免费的Web框架 ...
- 《Entity Framework 6 Recipes》中文翻译系列 (21) -----第四章 ASP.NET MVC中使用实体框架之在页面中创建查询和使用ASP.NET URL路由过虑
翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 4.2. 构建一个搜索查询 搜索数据是几乎所有应用的一个基本功能.它一般是动态的,因 ...
- Entity Framework 数据库初始化四种策略
策略一:数据库不存在时重新创建数据库 Database.SetInitializer<testContext>(new CreateDatabaseIfNotExists<testC ...
- Entity Framework数据库初始化四种策略
策略一:数据库不存在时重新创建数据库 程序代码 Database.SetInitializer<testContext>(new CreateDatabaseIfNotExists< ...
- Entity FrameWork初始化数据库的四种策略
程序猿就是苦逼,每天还得分出一些时间去写博文.天真的很热,今天就随便写一点啦! 1.EF初始化数据库的四中策略 EF可以根据项目中的模型自动创建数据库.下面我们就分类看看Entity Framewor ...
- Entity Framework Code First (四)Fluent API - 配置属性/类型
上篇博文说过当我们定义的类不能遵循约定(Conventions)的时候,Code First 提供了两种方式来配置你的类:DataAnnotations 和 Fluent API, 本文将关注 Flu ...
- Entity Framework学习笔记(四)----Linq查询(1)
请注明转载地址:http://www.cnblogs.com/arhat 从本章开始,老魏就介绍一下Entity Framework使用Linq来查询数据,也就是Linq To Entity.其实在E ...
- ASP.NET MVC with Entity Framework and CSS一书翻译系列文章之第四章:更高级的数据管理
在这一章我们将学习如何正确地删除分类信息,如何向数据库填充种子数据,如何使用Code First Migrations基于代码更改来更新数据库,然后学习如何执行带有自定义错误消息的验证. 注意:如果你 ...
随机推荐
- Nginx使用的php-fpm的两种进程管理方式及优化
PS:前段时间配置php-fpm的时候,无意中发现原来它还有两种进程管理方式.与Apache类似,它的进程数也是可以根据设置分为动态和静态的. php-fpm目前主要又两个分支,分别对应于php-5. ...
- QQ会员2018春节红包抵扣券项目背后的故事
欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 1. 活动数据 截止3月1日手Q运动红包会员礼包发放核销数据 参与红包活动用户数:2亿+ 发券峰值:52w/min 2. 需求背景 2.1 ...
- 基于 CentOS 搭建 WordPress 个人博客
欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 腾讯云提供了开发者实验室帮助用户搭建 WordPress 个人博客,教程内容如下,用户可以点击开发者实验室快速上机完成实验. 准备 LNMP ...
- 开源TSDB简介--Druid
开源TSDB简介--Druid Druid是一个以Java编写的开源分布式列式数据存储. Druid的目标是快速提取大量事件数据,并提供低延迟的查询. 德鲁伊的名字来源于许多角色扮演游戏中的变形德鲁伊 ...
- 结合manage.py,在flask项目中使用websocket模块--- flask-socketio
前言: - 为什么我要使用 flask-socketio模块,而不是flask-sockets? - 因为flask-socketio与前端流行的websocket库socke ...
- 【转】常用的邮箱服务器(SMTP、POP3)地址、端口
gmail(google.com)POP3服务器地址:pop.gmail.com(SSL启用 端口:995)SMTP服务器地址:smtp.gmail.com(SSL启用 端口:587) 21cn.co ...
- 跨页面传值之Cookie
3.客户端再次访问某站点 浏览器将携带Cookie信息的指令,将获得的信息参与编译. 4.将含有Cookie信息参与编译的页面发回给浏览器 其中如果有相关的设置Cookie的指令.将再次通过浏览器,写 ...
- Maven入门之简介与安装
一.Maven简介 1.什么是Maven? Maven是一个项目管理工具和集成编译工具,它主要包含如下内容: –一个项目对象模型(Project Object Model), –一组标准集合, –一个 ...
- 重构指南 - 使用多态代替条件判断(Replace conditional with Polymorphism)
多态(polymorphism)是面向对象的重要特性,简单可理解为:一个接口,多种实现. 当你的代码中存在通过不同的类型执行不同的操作,包含大量if else或者switch语句时,就可以考虑进行重构 ...
- Mysql 语句执行顺序
1.这样一个问题,作为一个开发人员需要掌握数据库的哪些东西? 在开发中涉及到数据库,基本上只用到了sql语句,如何写sql以及对其进行优化就比较重要,那些mysql的厚本书籍针对的是DBA,我们只需 ...