在博客园很久了,一直只看不说,这是发布本人的第一个博客。

总结一下在项目中,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();

}

}

相关链接:

在Entity Framework中使用事务

EntityFramework与TransactionScope事务和并发控制

微软的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

相关链接:

Entity Framework 4-多对多、自关联的关系

2)  Code First

尤其注意双向一对一关系,直接已对象一的主键设置为对象的主键和外键

相关链接:

Entity Framework 实体关系总结:one-to-one, one-to-many, many-to-many

**** Entity Framework Code First关系映射约定

Entiy Framework实践系列

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

a)       Table per Hierarchy (TPH)

b)       Table per Type (TPT)

c)       Table per Concrete class (TPC)

4、         EF Code First Migrations数据库迁移

Matrix 3.0

相关链接:

EF Code First Migrations数据库迁移

Code First Migrations

migrate.exe

【迁移】—Entity Framework实例详解

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函数的使用与实现

EF直接更新数据(不需查询)

(个人来说不是很推荐,还是比较倾向于先查)

7、         EF中Self-Tracking Entities

相关链接:

Self-Tracking Entities

使用自跟踪实体

8、         EF 批量更新、删除

相关链接:

Entity Framework Extended Library (EF扩展类库,支持批量更新、删除、合并多个查询等)

entity framework 批量更新,批量删除,分页 的扩展函数

Linq To SQL 批量更新方法汇总

9、         EF 6新特性

EF 6.0 TUTORIALS

1)  异步

相关链接:

Async query and Save

2)  Log

相关链接:

Database Command Logging

3)  Interception 拦截

相关链接:

Interception

EF架构~通过EF6的DbCommand拦截器来实现数据库读写分离~终结~配置的优化和事务里读写的统一

4)  批量增加删除

相关链接:

DbSet.AddRange & DbSet.RemoveRange:

10、     EF 注意事项

相关链接:

为提高entity framework 性能,要注意哪些事情.

11、    Configuring Relationships

1)  DataBase First

相关链接:

实体框架关系与导航属性

2)  Code First

相关链接:

Fluent API - Relationships

12、    并发模式

1)  DataBase First

并发模式

2)  Code First

Code First开发系列之管理并发和事务

高并发处理 - 乐观锁

Entity Framework 并发处理

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 项目使用心得的更多相关文章

  1. 记一次Entity Framework 项目的优化过程

    在博客园看了不少其他大神的经验.今天也抽空贡献点自己的经验(并不是说自己也是大神..小弟还只新手程序员去年才毕业的) 好了废话不多说,直接进入主题.(具体的好坏各位看官就随便看看吧..没有什么好坏之分 ...

  2. Entity Framework 6.1 学习系列1--概况、安装

    原文:Entity Framework 6.1 学习系列1--概况.安装 Entity Framework:实体框架,看名字就知道是针对模型数据的.这是MS推出的一款ORM工具. 与NHibernat ...

  3. Entity Framework 实体框架的形成之旅--实体数据模型 (EDM)的处理(4)

    在前面几篇关于Entity Framework 实体框架的介绍里面,已经逐步对整个框架进行了一步步的演化,以期达到统一.高效.可重用性等目的,本文继续探讨基于泛型的仓储模式实体框架方面的改进优化,使我 ...

  4. Entity FrameWork对有外键关联的数据表的添加操作

    前天做了一个MVC Entity FrameWork项目,遇到有外键关联的数据编辑问题.当你编辑的时候,按照正常的逻辑,把每个字段的数据都对号入座了,然后点击保存按钮,本以为会顺理成章的编辑数据,但是 ...

  5. 采用MiniProfiler监控EF与.NET MVC项目(Entity Framework 延伸系列1)

    前言 Entity Framework 延伸系列目录 今天来说说EF与MVC项目的性能检测和监控 首先,先介绍一下今天我们使用的工具吧. MiniProfiler~ 这个东西的介绍如下: MVC Mi ...

  6. N-Tier Entity Framework开源项目介绍

               N-Tier Entity Framework是一个基于微软Entity Framework的N层.NET解决方案. 并且与以下这此技术点无缝集成了: § WCF RIA Ser ...

  7. 旧项目如何切换到Entity Framework Code First

    Entity Framework Code First固然是好东西,然而如果是已经存在的旧有项目,如何简单方便的使用切换呢? 这里介绍一个VS的插件Entity Framework Power Too ...

  8. Entity Framework 的小实例:在项目中添加一个实体类,并做插入操作

    Entity Framework 的小实例:在项目中添加一个实体类,并做插入操作 1>. 创建一个控制台程序2>. 添加一个 ADO.NET实体数据模型,选择对应的数据库与表(Studen ...

  9. ASP.Net Core项目在Mac上使用Entity Framework Core 2.0进行迁移可能会遇到的一个问题.

    在ASP.Net Core 2.0的项目里, 我使用Entity Framework Core 2.0 作为ORM. 有人习惯把数据库的连接字符串写在appSettings.json里面, 有的习惯写 ...

随机推荐

  1. svn add xxx.txt 提示A (bin) xxx.txt

    [root@NGINX-APACHE-SVN iptables]# svn ci -m "add iptables.txt" Adding (bin) iptables/iptab ...

  2. 再谈API GateWay服务网关

    前面在谈微服务架构的时候,我博客上转过Chris Richardson 微服务系列中对微服务网关的描述: 通常来说,使用 API 网关是更好的解决方式.API 网关是一个服务器,也可以说是进入系统的唯 ...

  3. Unix系统编程()原子操作和竞争条件

    竞争状态是这样一种情形:操作共享资源的两个进程(或线程),其结果取决于一个无法预期的顺序,即这些进程获得CPU使用权的先后相对顺序. 以独占的方式创建一个文件 当同时指定了O_EXCL和O_CREAT ...

  4. API - 使用Default对象 - 基础篇

    在编写Spider Studio脚本时, Default对象是最常用最重要的一个, 其类型定义如下: Webus3.Spider.Controls.JQueryBrowser Default; 下面介 ...

  5. hive表支持中文设置

    默认创建表时说明中带有中文字段时会显示如下乱码信息: 解决方案: 在hive的元数据库中执行以下SQL语句,然后重新创建刚才的表即可 . ) character set utf8; ) charact ...

  6. Maven基础命令

    Maven 参数 -D 传入属性参数 -P 使用pom中指定的配置 -e 显示maven运行出错的信息 -o 离线执行命令,即不去远程仓库更新包 -X 显示maven允许的debug信息 -U 强制去 ...

  7. mnesia怎样改动表结构

    mnesia创建的时候须要指定表record结构,假设定义的record结构改动了,就要更新数据的表结构.否则mnesia无法正常读取和写入数据. 我们最開始是这样定义结构的 -record(pers ...

  8. Bitmap转灰度字节数组byte[]

    工作中遇到图片转灰度数组的须要,经过研究和大神的指导.终于得到例如以下两个方法.能够实现位图转灰度数组 简单的位图转灰度数组就是:得到位图中的每一个像素点,然后依据像素点得到RGB值,最后对RGB值, ...

  9. BI开发之——Mdx基础语法(2)(转至指尖流淌)

    结合webcast中老师的讲解,现在把基础语法应用通过几个案例应用如下: 一.维度的概念 上图中一个维度(Dimension):Region 改为度下有四个级别(Levels):country.pro ...

  10. Linux下Apache与httpd的区别与关系

    http://blog.csdn.net/yxfabcdefg/article/details/32324035