01-Entity FrameWork如何控制数据的变化
在Entity Framework所有操作数据就是更新EF容器中的实体状态
public enum EntityState
{
Added = ,
Deleted = ,
Detached = ,
Modified = 0x10,
Unchanged =
}
1、新增
StudentAddress address = new StudentAddress
{
Address = "地址" + DateTime.Now
};
db.StudentAddress.Add(address);
Console.WriteLine(db.Entry<StudentAddress>(address).State);//added
db.SaveChanges();
调用Add方法,实际上就是将实体状态改为added,然后通过saveChanges()保存到数据库
StudentAddress address = new StudentAddress
{
Address = "地址" + DateTime.Now
}; db.Entry<StudentAddress>(address).State = System.Data.Entity.EntityState.Added;
db.SaveChanges();
2、编辑
--第一种方法:
var address2 = db.StudentAddress.FirstOrDefault();
address2.Address = "ModifyFromEf2";//Modified
db.SaveChanges();
-- 1、与实体字段的值作比较,如果值不变,则不会产生update-sql语句
-- 2、修改了某个字段值,update sql语句只会set 修改某个字段,不会修改全部字段
-- 3、查询2次数据库

--第二种方法:
StudentAddress address = new StudentAddress
{
Id = ,
Address = "update地址"
}; //1、追加到EF容器中,状态为Detached
var entityEntry = db.Entry(address);//Detached
entityEntry.State = System.Data.Entity.EntityState.Modified;
db.SaveChanges();
--1、将一个游离的实体 追加到 EF 容器中
-- 2、将EF实体状态改为Modified
-- 3、修改所有的字段,无论是否变化

--第三种方法(综合前两种修改方法):
--查询1次数据库
--修改指定的字段
//1、追加到EF容器中,状态为Detached
var entityEntry = db.Entry(address);//Detached
Console.WriteLine("追加到EF容器:" + entityEntry.State); //2、修改指定字段Unchanged-->指定字段为修改
db.StudentAddress.Attach(address);//相当于entry.State = System.Data.EntityState.Unchanged;
Console.WriteLine("Attach-Unchanged:" + entityEntry.State); //Unchanged entityEntry.Property("Address").IsModified = true;
Console.WriteLine("修改后状态:" + entityEntry.State); //Modified db.SaveChanges();

3、删除亦是如此
StudentAddress address = new StudentAddress
{
Id = ,
Address = "u222pdate地址" + DateTime.Now
};
db.StudentAddress.Attach(address);//Detached db.StudentAddress.Remove(address);//或将其状态修改为:EntityState.Deleted;
db.SaveChanges();
4、源码
--每一种数据的变化,都会有相应的集合来保存这些实体的变化
如:ObjectStateManager
Dictionary<EntityKey, EntityEntry> _addedEntityStore
Dictionary<EntityKey, EntityEntry> _deletedEntityStore
Dictionary<EntityKey, EntityEntry> _unchangedEntityStore
Dictionary<EntityKey, EntityEntry> _modifiedEntityStore

--当实体变化发生改变时候,调用AddEntityEntryToDictionary,插入到集合中

--调用saveChange(),就会去获取这些变化,进行操作数据

01-Entity FrameWork如何控制数据的变化的更多相关文章
- LINQ TO SQL和Entity Framework 的关系 你了解多少?
1. LINQ TO SQL 和EF 特点: LINQ TO SQL和Entity Framework都是一种包含LINQ功能的ORM 也就是所谓的关系对象的映射.其中包括的有DBFrist ...
- Entity Framework 6 Recipes 2nd Edition(9-3)译->找出Web API中发生了什么变化
9-3. 找出Web API中发生了什么变化 问题 想通过基于REST的Web API服务对数据库进行插入,删除和修改对象图,而不必为每个实体类编写单独的更新方法. 此外, 用EF6的Code Fri ...
- 《Entity Framework 6 Recipes》中文翻译系列 (45) ------ 第八章 POCO之获取原始对象与手工同步对象图和变化跟踪器
翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 8-6 获取原始对象 问题 你正在使用POCO,想从数据库获取原始对象. 解决方案 ...
- Entity Framework使用EntityState和Attach来保存数据变化以及更新实体的个别字段
在使用Entity Framework作为ORM来存取数据的过程中,最常规的操作就是对数据对象的更新.本文将会包含如何Attach Entity到一个数据Context中,以及如何使用EntitySt ...
- Entity Framework基础01
学习了ADO.NET的相关知识,掌握了它对数据库表的基本操作,但是实际在开发项目应用中微软为我们开发ef这个ORM,使用它可以很方便的利用ADO.NET来操作DBMS,使得我们开发项目的着重点放在业务 ...
- Entity Framework 6 Recipes 2nd Edition(9-4)译->Web API 的客户端实现修改跟踪
9-4. Web API 的客户端实现修改跟踪 问题 我们想通过客户端更新实体类,调用基于REST的Web API 服务实现把一个对象图的插入.删除和修改等数据库操作.此外, 我们想通过EF6的Cod ...
- 《Entity Framework 6 Recipes》中文翻译系列 (41) ------ 第七章 使用对象服务之标识关系中使用依赖实体与异步查询保存
翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 7-7 标识关系中使用依赖实体 问题 你想在标识关系中插入,更新和删除一个依赖实体 ...
- Entity Framework 学习整理(分播客整理)
MSDN: http://msdn.microsoft.com/en-us/data/aa937723 台湾博客: http://www.dotblogs.com.tw/yc421206/ http: ...
- Entity Framework 基本概念
概念 LINQ to Entities 一种 LINQ 技术,使开发人员可以使用 LINQ 表达式和 LINQ 标准查询运算符,针对实体数据模型 (EDM) 对象上下文创建灵活的强类型化查询. ESQ ...
随机推荐
- Flink本地安装和创建Flink应用
本篇文章首发于头条号Flink本地安装和创建Flink应用,欢迎关注我的头条号和微信公众号"大数据技术和人工智能"(微信搜索bigdata_ai_tech)获取更多干货,也欢迎关注 ...
- 洛谷 P4136 谁能赢呢?
P4136 谁能赢呢? 题目描述 小明和小红经常玩一个博弈游戏.给定一个n×n的棋盘,一个石头被放在棋盘的左上角.他们轮流移动石头.每一回合,选手只能把石头向上,下,左,右四个方向移动一格,并且要求移 ...
- Analyzing Storage Performance using the Windows Performance Analysis ToolKit (WPT)
https://blogs.technet.microsoft.com/robertsmith/2012/02/07/analyzing-storage-performance-using-the-w ...
- SSD硬盘安装系统后要做的事
1***cmd>fsutil behavior query DisableDeleteNotify 0如果返回值是0,则代表TRIM处于开启状态:反之如果返回值是1,则代表TRIM处于关闭状态2 ...
- Angular CLI: 1.6.7 入门
当你使用npm或者yarn也安装不了angular-cli时,请使用淘宝镜像. Step1 npm i -g cnpm --registry=https://registry.npm.taobao.o ...
- win7下 sublime text2操作快捷键 - leafu
Ctrl+L 选择整行(按住-继续选择下行) Ctrl+KK 从光标处删除至行尾 ...
- mac 查看python路径
1,terminal : input: which python 2, terminal: input : python --->import sys ----> print sys ...
- PHP连接数据库(注冊页面的增删改查)
1.连接数据库 ---------–connect.php--------------– <?php //本地測试 $host = '127.0.0.1'; $port = 3306; $use ...
- HDU4267 树状数组 不连续区间修改(三维)
A Simple Problem with Integers Problem Description Let A1, A2, ... ...
- linux内核对块设备的使用
1 partition table 这里的分析以经典的MBR为例. 在MBR里面有partition table,每一项对应一个逻辑的块设备,partion table中的每一项是16个字节. 第一个 ...