Entity Framework 项目使用心得
在博客园很久了,一直只看不说,这是发布本人的第一个博客。
总结一下在项目中,EntityFramework使用的一下经验拿来和大家分享,希望对大家有用~
1、 在Entity Framework中使用事务
1) TransactionScope
using (BlogDbContext context =new BlogDbContext())
{
using (TransactionScope transaction =new TransactionScope())
{
context.BlogPosts.Add(blogPost);
context.SaveChanges();
postBody.ID = blogPost.ID;
context.EntryViewCounts.Add(
new EntryViewCount() { EntryID = blogPost.ID });
context.PostBodys.Add(postBody);
context.SaveChanges();
//提交事务
transaction.Complete();
}
}
相关链接:
EntityFramework与TransactionScope事务和并发控制
将不确定变为确定~transactionscope何时提升为分布式事务?
2) Working with Transactions (EF6 Onwards)
using (var dbContextTransaction = context.Database.BeginTransaction())
{
try
{
context.Database.ExecuteSqlCommand( @"UPDATE Blogs SET Rating = 5 WHERE Name LIKE '%Entity Framework%'" );
var query = context.Posts.Where(p => p.Blog.Rating >= 5);
foreach (var post in query)
{
post.Title += "[Cool Blog]";
}
context.SaveChanges();
dbContextTransaction.Commit();
}
catch (Exception)
{
dbContextTransaction.Rollback();
}
}
相关链接:
Working with Transactions (EF6 Onwards)
2、 EF 中 Many to Many relation
1) DateBase First
相关链接:
2) Code First
尤其注意双向一对一关系,直接已对象一的主键设置为对象的主键和外键
相关链接:
Entity Framework 实体关系总结:one-to-one, one-to-many, many-to-many
**** Entity Framework Code First关系映射约定
3、 EF 中的继承Inheritance
1) DataBase First
相关链接:
Entity Framework Modeling: Table Per Type Inheritance
Entity Framework Modeling : Entity Splitting
Entity Framework Modeling: Entity Splitting Part II (adding inheritance)
2) Code First
相关链接:
Inheritance Strategy in Code-First
c) Table per Concrete class (TPC)
4、 EF Code First Migrations数据库迁移
Matrix 3.0
相关链接:
Code First Migrations with an existing database
5、 EF中直接运行SQL命令
相关链接:
Entity Framework 小技巧二 —— 如何在EF中直接运行SQL命令
How to execute sql query from Entity framework
Entity Framework Code First执行SQL语句、视图及存储过程
6、 EF深入了解
相关链接:
Entity Framework 4.1 DbContext使用记之一——如何查找实体? DbSet.Find函数的使用与实现
(个人来说不是很推荐,还是比较倾向于先查)
7、 EF中Self-Tracking Entities
相关链接:
8、 EF 批量更新、删除
相关链接:
Entity Framework Extended Library (EF扩展类库,支持批量更新、删除、合并多个查询等)
entity framework 批量更新,批量删除,分页 的扩展函数
9、 EF 6新特性
1) 异步
相关链接:
2) Log
相关链接:
3) Interception 拦截
相关链接:
EF架构~通过EF6的DbCommand拦截器来实现数据库读写分离~终结~配置的优化和事务里读写的统一
4) 批量增加删除
相关链接:
DbSet.AddRange & DbSet.RemoveRange:
10、 EF 注意事项
相关链接:
为提高entity framework 性能,要注意哪些事情.
11、 Configuring Relationships
1) DataBase First
相关链接:
2) Code First
相关链接:
12、 并发模式
1) DataBase First
2) Code First
高并发处理 - 乐观锁
EF+MySQL乐观锁控制电商并发下单扣减库存,在高并发下的问题
13、 Fluent API
Entity Framework Code First (四)Fluent API - 配置属性/类型
14、Code first 数据库初始化
Understanding Database Initializers in Entity Framework Code First
15、EntityFramework Connection Management -- 数据库连接管理
EntityFramework Connection Management
Entity Framework 项目使用心得的更多相关文章
- 记一次Entity Framework 项目的优化过程
在博客园看了不少其他大神的经验.今天也抽空贡献点自己的经验(并不是说自己也是大神..小弟还只新手程序员去年才毕业的) 好了废话不多说,直接进入主题.(具体的好坏各位看官就随便看看吧..没有什么好坏之分 ...
- Entity Framework 6.1 学习系列1--概况、安装
原文:Entity Framework 6.1 学习系列1--概况.安装 Entity Framework:实体框架,看名字就知道是针对模型数据的.这是MS推出的一款ORM工具. 与NHibernat ...
- Entity Framework 实体框架的形成之旅--实体数据模型 (EDM)的处理(4)
在前面几篇关于Entity Framework 实体框架的介绍里面,已经逐步对整个框架进行了一步步的演化,以期达到统一.高效.可重用性等目的,本文继续探讨基于泛型的仓储模式实体框架方面的改进优化,使我 ...
- Entity FrameWork对有外键关联的数据表的添加操作
前天做了一个MVC Entity FrameWork项目,遇到有外键关联的数据编辑问题.当你编辑的时候,按照正常的逻辑,把每个字段的数据都对号入座了,然后点击保存按钮,本以为会顺理成章的编辑数据,但是 ...
- 采用MiniProfiler监控EF与.NET MVC项目(Entity Framework 延伸系列1)
前言 Entity Framework 延伸系列目录 今天来说说EF与MVC项目的性能检测和监控 首先,先介绍一下今天我们使用的工具吧. MiniProfiler~ 这个东西的介绍如下: MVC Mi ...
- N-Tier Entity Framework开源项目介绍
N-Tier Entity Framework是一个基于微软Entity Framework的N层.NET解决方案. 并且与以下这此技术点无缝集成了: § WCF RIA Ser ...
- 旧项目如何切换到Entity Framework Code First
Entity Framework Code First固然是好东西,然而如果是已经存在的旧有项目,如何简单方便的使用切换呢? 这里介绍一个VS的插件Entity Framework Power Too ...
- Entity Framework 的小实例:在项目中添加一个实体类,并做插入操作
Entity Framework 的小实例:在项目中添加一个实体类,并做插入操作 1>. 创建一个控制台程序2>. 添加一个 ADO.NET实体数据模型,选择对应的数据库与表(Studen ...
- ASP.Net Core项目在Mac上使用Entity Framework Core 2.0进行迁移可能会遇到的一个问题.
在ASP.Net Core 2.0的项目里, 我使用Entity Framework Core 2.0 作为ORM. 有人习惯把数据库的连接字符串写在appSettings.json里面, 有的习惯写 ...
随机推荐
- C#趣味程序---爱因斯坦的台阶问题
问题:设有一阶梯,每步跨2阶.最后余1阶.每步跨3阶.最后余2阶:每步跨5阶.最后余4阶:每步跨6阶.最后余5阶:每步跨7阶.刚好到阶顶.问共同拥有多少阶梯? using System; namesp ...
- 0067 MySQL的日期字段的取值用单引号
这两天在做sql练习题http://www.cnblogs.com/zxx193/p/4000467.html的时候,涉及到下面的建表+插数据操作 CREATE TABLE t1( s_no VARC ...
- Makefile学习之路6——让编译环境更加有序
在大多项目中都会合理设计目录结构来提高维护性,在编译一个项目时会产生大量中间文件,如果中间文件直接和源文件放在一起,就显得杂乱而不利于维护.在为现在这个complicated项目编写makefile之 ...
- 基于jquery仿360网站图片选项卡切换代码
今天给大家分享一款基于jquery仿360网站图片选项卡切换代码.这款实例适用浏览器:IE8.360.FireFox.Chrome.Safari.Opera.傲游.搜狗.世界之窗.效果图如下: 在线预 ...
- Centsos7修改密码
CentOS 7.0 进入单用户模式修改Root密码 时间:2017-05-02 01:10来源:blog.csdn.net 作者:海哥_大大的Java 举报 点击:506次 一.启动时,随便按 ...
- Java中float/double取值范围与精度
Java浮点数 浮点数结构 要说清楚Java浮点数的取值范围与其精度,必须先了解浮点数的表示方法,浮点数的结构组成,之所以会有这种所谓的结构,是因为机器只认识01,你想表示小数,你要机器认识小数点这个 ...
- Hibernate Annotation 字段 默认值
http://emavaj.blog.163.com/blog/static/133280557201032262741999/ ——————————————————————————————————— ...
- ResultSet是结果集对象
ResultSet是结果集对象 DriverManager管理一组驱动程序 PreparedStatement预编译的,用来发送和执行SQL语句的
- 浅谈Spring(一)
Spring 框架是一个分层架构,由 7 个定义良好的模块组成.Spring 模块构建在核心容器之上,核心容器定义了创建.配置和管理 bean 的方式. watermark/2/text/aHR0cD ...
- adb server is out of date.killing的解决办法
当把手机连接到电脑端口运行adb程序调试时,出现了下面这样的情况: 分析:出错的原因是adb的端口被其他程序的进程占领了,所以要做的就是找到并kill该进程. 工具/原料 cmd.exe. ...