连接情景中的CRUD操作:

连接场景中的CRUD操作是一项相当简单的任务,因为默认情况下,上下文会自动跟踪实体在其生命周期中发生的更改,前提是AutoDetectChangesEnabled为true。

以下示例显示了如何在连接方案(在上下文的范围内)中添加,更新和删除实体,然后该实体又将在数据库上执行插入,更新和删除命令。上下文将自动检测更改并更新实体的状态。

断开的实体:

当我们得到一个断开的实体图,甚至一个断开的实体时,我们需要做两件事情。首先,我们需要使用新的上下文实例附加实体,并使上下文知道这些实体。其次,手动为这些实体设置合适的EntityStates,因为新的上下文实例不知道在断开的实体上执行的操作,所以新的上下文不能应用适当的EntityState。

示意图:

DbSet.Add():

DbSet.Add()方法将整个实体图形附加到新的上下文,并自动将添加的实体状态应用于所有实体。

使用父DbSet实体的Add方法将整个实体图附加到具有Added状态的新的上下文实例。调用ctx.Savechanges()将为所有实体执行插入命令,这会将新行插入到适当的数据库表中。

DbSet.Attach():

DbSet.Attach方法将整个实体图形附加到具有不变实体状态的新上下文中。

Attach方法只会将实体图附加到上下文中,所以我们需要为每个实体找到适当的实体状态并手动应用。

DbContext.Entry():

DbContext的Entry方法返回指定实体的DbEntityEntry实例。DbEntityEntry可以用来改变一个实体的状态。

在断开的情况下使用DBContext添加新实体:

在断开的情况下使用DBContext更新现有实体:

步骤:

①从数据库获取现有的学生。

②将学生姓名改为上下文范围(断开模式)

③将修改的实体传递给Entry方法以获取其DBEntityEntry对象,然后将其状态标记为Modified

④调用SaveChanges()方法将学生信息更新到数据库中。

在断开的情况下使用DBContext删除实体:

使用DbContext添加实体图:

我们可以使用DbSet.Add()方法将整个实体图形附加到上下文中,并将所有实体的状态设置为Added。

使用DbContext更新实体图:

在断开的情况下更新实体图是一项复杂的任务。

在断开的场景中更新实体图形的问题在于,上下文不知道在客户端执行了哪些操作。根据下图,新的上下文不知道每个实体的状态:

在断开的情况下识别实体状态的模式:

在断开的情况下,有几种方法(如下所示)来标识实体状态:

  1. 使用实体的PrimaryKey(Id)属性
  2. 在实体集中设置一个属性来保存状态 (学习的时候可以这样设计)

1)使用实体的PrimaryKey属性:

您可以使用每个实体的PrimaryKey(Id)属性来确定其实体状态。但是,您必须决定使用以下哪个架构规则:

  • 每种类型的实体都必须有Id属性(PK)
  • Id属性的默认值应为0

在断开的情况下,context2不知道每个实体的状态。它必须通过使用StandardId来确定Standard实体的状态,并使用TeacherId属性来确定Teacher实体的状态。如果StandardId和TeacherID的值为零,则表示它是一个新的实体,如果它不是零,那么它是一个修改的实体。(这个比较好理解)

优点:

  • 无需额外的编码/处理来确定实体状态。
  • 很好的表现。

缺点:

  • 每个实体类型都需要有一个Id属性。它不能确定没有Id属性的实体的状态。
  • 无法识别未更改的实体。即使实体没有被改变,它也被设置为Modified状态。因此,对于未更改的实体存在不必要的数据库更新语句。
  • 无法处理删除实体场景。它需要单独处理删除。

2)在每个实体拥有状态:

①创建一个接口,声明一个枚举

②让实体继承改接口

上面的代码修改了一个Teacher,新建了一个Teacher,和新建了一个Standar

优点:

  • 无需额外的编码/处理来确定实体状态
  • 已添加,已修改,已删除和未更改状态正确
  • 没有不必要的更新调用不变的实体。

坏处:

  • 需要在断开模式下设置每个实体的适当状态。所以在断线模式下需要格外小心。

实体框架中的并发:

SQL里面处理并发则是使用多线程来处理,对有并发的数据实现同步,只能一个一个的去访问数据。再就是使用锁,在有人访问这个数据的时候别人是访问不了的。

①Student表里面有个RowVersion字段是 timestamp(时间戳)类型,在添加,更新的时候会自动变化

②打开设计器修改Student实体中的RowVersion属性,更改并发模式

③测试并发

   数据库中只修改了一次

至于怎么去处理并发这里就不做深入研究了。

Entity Framework 五的更多相关文章

  1. 《Entity Framework 6 Recipes》中文翻译系列 (22) -----第五章 加载实体和导航属性之延迟加载

    翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 第五章 加载实体和导航属性 实体框架提供了非常棒的建模环境,它允许开发人员可视化地使 ...

  2. 《Entity Framework 6 Recipes》中文翻译系列 (23) -----第五章 加载实体和导航属性之预先加载与Find()方法

    翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 5-2  预先加载关联实体 问题 你想在一次数据交互中加载一个实体和与它相关联实体. ...

  3. 《Entity Framework 6 Recipes》中文翻译系列 (24) ------ 第五章 加载实体和导航属性之查询内存对象

    翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 5-4  查询内存对象 问题 你想使用模型中的实体对象,如果他们已经加载到上下文中, ...

  4. 《Entity Framework 6 Recipes》中文翻译系列 (25) ------ 第五章 加载实体和导航属性之加载完整的对象图和派生类型上的导航属性

    翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 5-5  加载完整的对象图 问题 你有一个包含许多关联实体的模型,你想在一次查询中, ...

  5. 《Entity Framework 6 Recipes》中文翻译系列 (26) ------ 第五章 加载实体和导航属性之延缓加载关联实体和在别的LINQ查询操作中使用Include()方法

    翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 5-7  在别的LINQ查询操作中使用Include()方法 问题 你有一个LINQ ...

  6. 《Entity Framework 6 Recipes》中文翻译系列 (27) ------ 第五章 加载实体和导航属性之关联实体过滤、排序、执行聚合操作

    翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 5-9  关联实体过滤和排序 问题 你有一实体的实例,你想加载应用了过滤和排序的相关 ...

  7. 《Entity Framework 6 Recipes》中文翻译系列 (28) ------ 第五章 加载实体和导航属性之测试实体是否加载与显式加载关联实体

    翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 5-11  测试实体引用或实体集合是否加载 问题 你想测试关联实体或实体集合是否已经 ...

  8. 《Entity Framework 6 Recipes》中文翻译系列 (29) ------ 第五章 加载实体和导航属性之过滤预先加载的实体集合和修改外键关联

    翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 5-13  过滤预先加载的实体集合 问题 你想过滤预先加载的实体集合,另外,你想使用 ...

  9. Entity Framework学习笔记(五)----Linq查询(2)---贪婪加载

    请注明转载地址:http://www.cnblogs.com/arhat 在上一章中,我们使用了Linq对Entity Framework进行了一个查询,但是通过学习我们却发现了懒加载给我来的性能上的 ...

随机推荐

  1. Linux利器strace

    strace常用来跟踪进程执行时的系统调用和所接收的信号. 在Linux世界,进程不能直接访问硬件设备,当进程需要访问硬件设备(比如读取磁盘文件,接收网络数据等等)时,必须由用户态模式切换至内核态模式 ...

  2. FZU 1921——栀子花开——————【线段树单点更新】

    栀子花开 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Submit Status  ...

  3. git打补丁、还原补丁

    打补丁.还原补丁 1.两个commit间的修改(包含两个commit,<r1>.<r2>表示两个提交的版本号,<r1>是最近提交) git format-patch ...

  4. 今天研究Unity Ioc 框架

    今天研究Unity Ioc 框架,被自己坑了两个多小时. 运行就报错,反反复复检查了很多次,配置文件,代码都没有问题,也从新写了好几遍. 最后仔细看报错消息才知道,config文件没有生成到目录……… ...

  5. Mysql数据库死锁分析相关概念

    参考博客: mysql死锁问题分析(https://www.cnblogs.com/LBSer/p/5183300.html) mysql insert锁机制(http://yeshaoting.cn ...

  6. Linux 套接字编程 - TCP连接基础

    第五章的内容,实现一个echo服务器和对应的客户端,主要收获: 0. TCP socket编程主要基本步骤 1. SIGCHLD信号含义(子进程退出时向父进程发送,提醒父进程对其状态信息进行一个获取) ...

  7. python占位符%s,%d,%r,%f

    input接收的所有输入默认都是字符串格式 1.%s代表字符串占位符 conn, client_addr = phone.accept() print(conn) print(client_addr) ...

  8. 设备信息工具pv-jd快速上手

    pv-jd 这是一个判断设备信息的小工具,可以判断出移动端还是PC端,提供了多种API 快速开始 安装npm install pv-jd -S 示例 import {judgeDevice, judg ...

  9. 有关table布局时tr 属性display:block显示布局错乱

    display:block display:block是可以把非块级元素强制转换为块级元素显示,如内嵌元素span,原来不支持设置宽高,宽度是由内容撑开的; display:table-row tab ...

  10. 【起航计划 036】2015 起航计划 Android APIDemo的魔鬼步伐 35 App->Service->Messenger Service Messenger实现进程间通信

    前面LocalService 主要是提供同一Application中组件来使用,如果希望支持不同应用或进程使用Service.可以通过Messenger.使用Messgener可以用来支持进程间通信而 ...