EF Core 快速上手——EF Core 入门
EF Core 快速上手——EF Core 介绍
本章导航
- 从本书你能学到什么
- 对EF6.x 程序员的一些话
- EF Core 概述
- 1.3.1 ORM框架的缺点
第一个EF Core应用

本文是对《Entity framework in action》部分章节的翻译,某些场景也会附上笔者实践的Demo。尽管很认真的斟酌,但是水平有限,还请各位批评和斧正。
Entity Framework Core, 或者 EF Core,是一个方便软件工程师访问数据库的库。有很多方法来构建这样的一个库,但是EF Core 被设计为一个对象和关系的映射器(也就是我们常说的ORM框架)。ORM是把两个世界的东西映射在一起,一个是关系型数据库自身API,另一个是面向对象世界的类和软件代码。EF Core的优势在于,让软件工程师能够通过代码快速访问数据库。
EF Core,微软发布于2016年,它具有跨平台性:它可以运行在Windows,Linux,mac等操作系统上。它使用EF Core来命名的主要原因,确实是因为他是.NET Core 原创的一部分(但是.NET Core 也可以用于现存的.NET Framework)。
EF Core, ASP.NET Core (服务端APP), 和 .NET Core都是开源的,并且都有提供给开发团队交流的活跃的issues页面。
EF Core不是 Entity Framework的第一个版本.现存的大家最为熟知的Entity Framework版本是EF 6.X. EF Core一开始就汲取了Entity Framework 4到6.x多年积累的经验和反馈意见。她保持了和EF 6.x一样接口,但是在底层做了重大改造。比如,它支持非关系性数据库,这在EF 6.x中并没有设计。作为EF5和6.x的用户,我能看到EF Core相对于此前的版本有了提高,同时也看到我喜欢的那些在EF 6.x中的特性在EF Core中还没有(尽管那些特性已经在列入了开发日程)。
本书的目标读者可以是那些从未使用过Entity Framework的开发人员,也可以是那些EF 6.x老手,还可以是那些想了解EF Core 能做什么的人。我假定你们都熟悉.net 和 C#开发,至少对关系型数据库有所了解。但我不假定你们会使用SQL语言(一种用于大多数关系型数据库的语言),因为EF Core能够帮你做太多的事情(不用sql).但是,我会想你展示EF Core生成的SQL,因为它能帮助您理解发生了什么。使用EF的某些高级特性需要有SQL知识,而本书会提供大量的插图来帮助您学习。
本章将通过也小例子来价绍EF Core的使用。这个例子会调用EF Core.你也将会你看到 EF Core是底层是如何翻译软件命令并访问数据库。对EF Core底层原理的概览有助于阅读本书的其余部分。
1.1 从本书你能学到什么
本书被分为三个部分.除了本章,第一部分还有其它四章。
学完第一部分,你将能够使用关系数据库构建一个.net 应用。但是数据库的组织方式留给EF Core来处理。举个例子,EF Core 默认会设置数据库字段的类型和大小,这会浪费一点点空间。
第二部分,会涉及到如何和为什么要修改默认配置,并深入地查看一些EF Core 命令。学完第二部分,您将能够根据您的想法,用EF Core精准的创建数据库.或者链接那些具有特定结构和设计的数据库。并且,通过使用EF Core的一些高级特性,您能够改变你.net 应用程序中数据库数据的暴露方式——比如,控制软件更加谨慎地访问数据或者构建代码来自动跟踪数据库的变化。
第三部分,全是关于提高您的技能,以及使您能够更好地开发和调试EF Core应用程序。我展示了一个真实的EF Core应用,从一系列熟知的模式和实践入手,而这是您是可以拿来即用的。阅读这些章节,你可单元测试,对EF Core进行扩展,而最重要的是,可以发现和修复EF Core 的性能问题。
1.2 对EF6.x 程序员的一些话
如果你是Entity Framework的新手,可以跳过本节。
如果你是熟悉EF 6.x的读者,EF Core的大部分你会熟悉。为了引导您快速地阅读完本书,我增加了EF6的说明。
EF 6
在本书中,请留意这样的说明。他们指出了EF Core和EF 6.x的不同之处。同时,一定要看每章末尾的总结。他们会指出EF Core和EF 6.x的重大变化。
我将以自己学习EF Core经历给你一些建议。我太熟悉EF 6.x,在我刚开始学习EF Core的时候,却变成了一个问题。
我使用EF 6.x的方法处理问题,但不知道EF Core 有新的方法解决这些问题。在大多数情况中,这些方法是类似的,但是一些方面,却不是。
对于使用过EF 6.x的读者,我的建议是请把EF Core当成一个新的库,就当是某些人模仿EF 6.x写的。但是,必须明白它与EF 6.x不同。
那样,你会注意到EF Core中c处理问题的新的和不同的方法。
1.3 EF Core 概述
.NETCore用于关系型数据库和.net世界中类和代码的映射,俗称ORM框架。表1.1展示了他们之间的映射关系。

1.3.1 ORM框架的缺点
造一个好的ORM框架非常困难。尽管EF 6.x和EF Core看起来很好用,某些时候的EF Core的“魔法”让你惊叹。在我们深入学习EF Core工作原理之前,请让我提出两个问题。
第一个是对象关系的不匹配。数据库服务器和面向对象的软件使用不同的规则:数据库使用主键来定义一条记录的唯一性,然而,.net类的实例默认是以它们的引用来区分。EF Core帮助你处理了大部分,但是.net 类会被这些key和value"污染"。大多数情况下,EF Core会运行良好,但是为了适应数据库,对于纯软件的项目解决方案,有时候我们处理的有一点点不同。你将在第二章看的例子就是多对多关系:在C#中处理很容易,但是在数据库中有点繁琐。
第二个问题是ORM框架——特别像EF Core这样尽善尽美的框架——把数据库隐藏的很好以至于有时候你会忘记数据库的底层是如何运作的。这个问题回导致你的代码在测试APP上运行良好,但是在数据库很复杂且同时有大量用户时的真实环境中表现糟糕。
这就是我为什么会花时间在本章,展示EF Core内部是如何工作的,以及如何生成SQL的。你越了解EF Core的工作原理,你就越能够写出好的EF Core代码。更重要的是,当它不工作的时候你知道做什么。
NOTE:
贯穿于这本书,我本着"先跑起来,但是在我需要的时候能够变得更快"的思路来使用EF Core.
EF Core 让我开发快速,但是我也意识到,因为EF Core或者我没有很好的使用EF Core导致在一些特定的业务需求,数据库访问的性能不够好。第5章会介绍如何隔离你EF Core,这样你就能以最小的副作用体调整它。第13章将介绍如何发现和优化那些不够快速的EF Core代码。
1.4 第一个EF Core应用
参考
- 《Entity Framework Core In Action》


EF Core 快速上手——EF Core 入门的更多相关文章
- EF Core 快速上手——EF Core的三种主要关系类型
系列文章 EF Core 快速上手--EF Core 入门 本节导航 三种数据库关系类型建模 Migration方式创建和习修改数据库 定义和创建应用DbContext 将复杂查询拆分为子查询 本 ...
- EF Core 快速上手——创建应用的DbContext
系列文章 EF Core 快速上手--EF Core 入门 EF Core 快速上手--EF Core的三种主要关系类型 本节导航 定义应用的DbContext 创建DbContext的一个实例 创建 ...
- .net core快速上手
2014年11月12日的Connect ();开发者活动上宣布将.NET堆栈基于MIT协议开源,并且提供开源保证,托管在Github上.当时的版本与最终目标相距甚远,然而有一点可以肯定的是,这是一个与 ...
- 快速上手 Rook,入门云原生存储编排
Rook 是一个开源 cloud-native storage orchestrator(云原生存储编排器),为各种存储解决方案提供平台.框架和支持,以与云原生环境进行原生集成. Rook 将存储软件 ...
- Flask入门和快速上手
目录 Flask入门和快速上手 python三大主流框架对比 Flask安装 依赖 可选依赖 创建flask项目 flask最小应用--hello word 非法导入名称 调试模式 路由 唯一的 UR ...
- 聊天系统Demo,增加Silverlight客户端(附源码)-- ESFramework 4.0 快速上手(09)
在ESFramework 4.0 快速上手 -- 入门Demo,一个简单的IM系统(附源码)一文中,我们介绍了使用ESFramework的Rapid引擎开发的winform聊天程序,本文我们将在之前d ...
- Entity Framework Core(EF Core) 最简单的入门示例
目录 概述 基于 .NET Core 的 EF Core 入门 创建新项目 更改当前目录 安装 Entity Framework Core 创建模型 创建数据库 使用模型 基于 ASP.NET Cor ...
- 【笔记目录1】【jessetalk 】ASP.NET Core快速入门_学习笔记汇总
当前标签: ASP.NET Core快速入门 共2页: 1 2 下一页 任务50:Identity MVC:DbContextSeed初始化 GASA 2019-03-02 14:09 阅读:16 ...
- WebAPI调用笔记 ASP.NET CORE 学习之自定义异常处理 MySQL数据库查询优化建议 .NET操作XML文件之泛型集合的序列化与反序列化 Asp.Net Core 轻松学-多线程之Task快速上手 Asp.Net Core 轻松学-多线程之Task(补充)
WebAPI调用笔记 前言 即时通信项目中初次调用OA接口遇到了一些问题,因为本人从业后几乎一直做CS端项目,一个简单的WebAPI调用居然浪费了不少时间,特此记录. 接口描述 首先说明一下,基于 ...
随机推荐
- 我的新纪元Day01
在我刚刚开通博客园后,想了好久.不知道第一次随笔该写点什么,想写些自己学到的知识,但技术上还是菜鸟的我完全不知道我能向别人分享什么,想到这里有些沮丧. 但万事开头难,只要我入了门,广阔的编程语言的世界 ...
- oracle服务的一些问题,先发2个,以后慢慢添加~~
OracleOraDb11g_home1TNSLister服务启动后停止 解决办法: 1. 修改文件C:\app\zhuwei\product\11.1.0\db_1\NETWORK\ADMIN\li ...
- Hive 查询元数据库获取某个分区的count数
=========查询分区的大小========= select d.NAME,t.TBL_NAME,p.PART_NAME,prm.PARAM_KEY,prm.PARAM_VALUE from TB ...
- Scala脚本化-Ammonite
Scala语言定义: Scala combines object-oriented and functional programming in one concise, high-level lang ...
- ASP.NET Core 实战:基于 Dapper 扩展你的数据访问方法
一.前言 在非静态页面的项目开发中,必定会涉及到对于数据库的访问,最开始呢,我们使用 Ado.Net,通过编写 SQL 帮助类帮我们实现对于数据库的快速访问,后来,ORM(Object Relatio ...
- ssm框架搭建和整合流程
Spring + SpringMVC + Mybatis整合流程 1 需求 1.1 客户列表查询 1.2 根据客户姓名模糊查询 2 整合思路 第一步:整合dao层 ...
- 更好用的css命名方式——BEM命名
一.什么是BEM? BEM代表块(Block),元素(Element),修饰符(Modifier).无论是什么网站页面,都可以拆解成这三部分. 二.带你认识网页 我们来看一下qq的官网,它可以由三个块 ...
- .NETCore 下支持分表分库、读写分离的通用 Repository
首先声明这篇文章不是标题党,我说的这个类库是 FreeSql.Repository,它作为扩展库现实了通用仓储层功能,接口规范参考 abp vnext 定义,实现了基础的仓储层(CURD). 安装 d ...
- 玩转Spring Cloud之服务注册发现(eureka)及负载均衡消费(ribbon、feign)
如果说用Spring Boot+Spring MVC是开发单体应用(或单体服务)的利器,那么Spring Boot+Spring MVC+Spring Cloud将是开发分布式应用(快速构建微服务)的 ...
- 记ibatis使用动态列查询问题(remapresults)
今天在项目开发中,遇到了一个问题:使用ibatis 动态查询列时,每次返回的结果列都是第一次查询的结果列,然而控制台执行的SQL语句时包含该结果列的.比如: <select id="g ...