Entity Framework Core(EF Core)是一个轻量级的,可扩展和实体框架的跨平台版本。今天,我们宣布 Entity Framewor Core 1.1 正式可用了。

EF Core 和 .NET Core 遵循相同的发行周期。每2个月不断的改进和每6个月的新功能发布。这是自1.0的第一个功能版本。

请务必阅读位于这个帖子的末尾的升级到1.1这个章节,有相关升级到1.1版本重要信息。

1.1 版本有什么

1.1版本的重点是解决人们采用EF Core 中遇到的问题。这包括修正了bug,增加了一些的那些尚未在EF Core实现的重要功能。虽然我们已经取得了这方面的一些良好的进展,但是我们也承认EF Core 仍然不会是对大家来说最好的选择,更多详细信息可以看这篇 EF Core和EF6.x比较。

Bug修复

在1.1版本有包含超过100个bug的修复。参见 EF Core 1.1 版本说明了解更多详情。

改进LINQ翻译

在1.1版本中,我们在提高Linq 对 EF Core 的支持取得了良好的进展。这使得更多的查询成功执行,有更多的逻辑在数据库进行执行(而不是在内存中)。

DbSet.Find

DbSet.Find(...)是存在于EF6.x并在 EF Core 中比较常见的一个 API。它可以让你方便地查询基于其主键值的实体。如果实体已经加载到上下文,则它直接返回而不再次查询数据库。

using (var db = new BloggingContext())
{    var blog = db.Blogs.Find(1);
}

映射字段

新的流式API HasField(...) 方法 允许你在属性中配置一个数据库不同名字的字段。
这对于只读属性是非常有用的,而不是一个 get / set的属性。有关详细的指导,请参阅我们的文档中的Backing Field相关文章。

public class BloggingContext : DbContext{...    protected override void OnModelCreating(ModelBuilder modelBuilder)    {modelBuilder.Entity<Blog>().Property(b => b.Url).HasField("_validatedUrl");}
}

显式加载

显式加载允许您加载DBContext上下文中跟踪到的实体的导航属性里面的内容。欲了解更多信息,请参见我们的文档中的加载相关数据文章。

using (var db = new BloggingContext())
{    var blog = db.Blogs.Find(1);db.Entry(blog).Collection(b => b.Posts).Load();db.Entry(blog).Reference(b => b.Author).Load();
}

从 EF6.x 增加的 EntityEntry的API

我们已经加入在EF6.x.是可用的但是还没有添加到 EF Core 中的EntityEntry的相关 API, 这包括 Reload()GetModifiedProperties()GetDatabaseValues()等。这些API一般通过 DbContext.Entry(object entity) 调用。

弹性连接

弹性连接将会自动重试失败的数据库命令。SQL Server提供了一个专门针对SQL Server的执行策略(包括SQL Azure的)。识别到异常类型,可以重试并且为最大重试设置合理的默认值,重试之间的延迟等。更多信息,可以在我们的文档请参阅弹性连接的文章。

其实一个就是给你的数据库上下文配置执行策略,在 ASP.NET Core 应用程序中,通常情况下是在 OnConfiguring方法中,或者是在 Startup.cs 里面。

protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder){optionsBuilder.UseSqlServer(            "connection string",options => options.EnableRetryOnFailure());
}

支持 SQL Server 内存优化表

内存优化表是SQL Server 2014+ 的功能。现在,您可以指定一个实体映射到内存优化表。欲了解更多信息,请参阅我们的文档中的内存优化表文章。

protected override void OnModelCreating(ModelBuilder modelBuilder){modelBuilder.Entity<Blog>().ForSqlServerIsMemoryOptimized();
}

简化 service 替换

在EF Core 1.0中你可以取代EF使用其内部服务,但这是很复杂的,需要你拿到 EF依赖注入容器的控制权来使用。在1.1中,这个要简单得多。在配置上下文时候使用ReplaceService(...) 方法就行了。在 ASP.NET Core 应用程序中,这通常是在Startup.cs 文件中的 OnConfiguring(...) 方法中。

protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder){optionsBuilder.UseSqlServer("connection string");optionsBuilder.ReplaceService<SqlServerTypeMapper, MyCustomSqlServerTypeMapper>();
}

升级到1.1

如果您正在使用的EF团队提供的连接数据库的程序包(SQL Server, SQLite, InMemory),那就升级提供的程序包就行了。

PM> Update-Package Microsoft.EntityFrameworkCore.SqlServer

如果您使用的是第三方数据库提供程序,检查一下看看他们是否已经发布新版本,它取决于1.1.0更新。如果他们有,那么就升级到新版本。如果没有, 那么你应该能够升级他们依赖的EF Core Relational 组件。大部分的新特性数据库组件提供者在1.1不需要修改。我们已经做了一些测试,以确保数据库提供商依赖1.0和1.1,但没有做详尽的测试。

PM> Update-Package Microsoft.EntityFrameworkCore.Relational

升级工具包

如果您正在使用Tools 工具包,那肯定就要升级了。需要注意的是Tools版本为 1.1.0-preview4 因为Tools还没有达到其稳定版本。

PM> Update-Package Microsoft.EntityFrameworkCore.Tools -Pre

如果你在使用 ASP.NET Core,使用dotnet ef命令,那么你需要更新 project.json 的Tools部分使用新 Microsoft.EntityFrameworkCore.Tools.DotNet 包取代 Microsoft.EntityFrameworkCore.Tools 1.0 的包。由于.NET Cli,所以对我们来说分离dotnet ef到这个单独的包已经是必要的了。

json"tools": {   "Microsoft.EntityFrameworkCore.Tools.DotNet": "1.1.0-preview4"},

原文地址:http://www.cnblogs.com/savorboard/p/efcore11-announcing.html


.NET社区新闻,深度好文,微信中搜索dotNET跨平台或扫描二维码关注

Entity Framework Core 1.1 升级通告相关推荐

  1. Entity Framework Core 2.1带来更好的SQL语句生成方案

    微软发布了Entity Framework Core2.1,为EF开发者带来了很多期待已久的特性.EF Core 2.1增加了对SQL GROUP BY的支持,支持延迟加载和数据种子等. EF Cor ...

  2. Entity Framework Core 2.0 特性介绍和使用指南

    前言 这是.Net Core 2.0生态生态介绍的最后一篇,EF一直是我喜欢的一个ORM框架,随着版本升级EF也发展到EF6.x,Entity Framework Core是一个支持跨平台的全新版本, ...

  3. Entity Framework Core 3.1 和 Entity Framework 6.4 发布

    目前,Entity Framework Core 3.1 和 Entity Framework 6.4 已正式发布. EF Core 3.1的获取方式 EF Core 3.1 作为一组 NuGet 软 ...

  4. 使用ASP.NET Core和Entity Framework Core实现Angular 7 SPA CRUD

    目录 Angular 7 Angular Core变化 Angular CLI更改 升级到Angular 7 添加新项目 创建新项目 使用Angular的前端设计和实现 添加模型和配置文件 添加Boo ...

  5. Entity Framework Core 2.0的新特性

    虽然EF Core 2.0存在大量槽点,但是它也给出了不少亮点.在本文中,我们将介绍这次发布版的部分亮点. \\ 数据库表切分(Table Splitting) \\ ORM常被吐槽是总是对所请求数据 ...

  6. ABP官方文档翻译 9.2 Entity Framework Core

    Entity Framework Core 介绍 DbContext 配置 在Startup类中 在模块PreInitialize方法中 仓储 默认仓储 自定义仓储 应用程序特定基础仓储类 自定义仓储 ...

  7. Entity Framework Core 2.0 使用入门

    本文转载自作者:晓晨Master(李志强) 原文章地址 https://www.cnblogs.com/stulzq/p/7717873.html 一.前言 Entity Framework(后面简称 ...

  8. Entity Framework Core介绍(1)

    介绍 Entity Framework (EF) Core 是轻量化.可扩展和跨平台版的常用 Entity Framework 数据访问技术. EF Core 可用作对象关系映射程序 (O/RM),以 ...

  9. oracle精简版_使用Entity Framework Core访问数据库(Oracle篇)

    前言 哇..看看时间 真的很久很久没写博客了 将近一年了. 最近一直在忙各种家中事务和公司的新框架  终于抽出时间来更新一波了. 本篇主要讲一下关于Entity Framework Core访问ora ...

最新文章

  1. 2011寒假-操作系统学习笔记
  2. Linux System and Performance Monitoring(Memory篇)
  3. java编程打印以下图形,分享java打印简单图形的实现代码
  4. JAVA 操作系统已经来到第五个版本了 现陆续放出三个版本 这是第二个版本
  5. [Swift]扩展String类:实现find()查找子字符串在父字符串中的位置
  6. 苹果新iPad Pro代工订单或将推升富士康4月份营收
  7. 是不正确的python语句_Python if语句读取不正确
  8. Linux日志管理五大命令详解
  9. 大学计算机四级报名,2016下半年安徽理工大学计算机四级报名
  10. [经典控件]按钮和菜单
  11. 转载! 一图读懂 SignalR
  12. 为linux扩展swap分区
  13. 多益网络 2016 春季实习校招笔试回顾(C++游戏后台)
  14. java记事本打开功能_Java简易实现记事本的打开与保存
  15. 用C语言实现猜单词的小游戏
  16. [转载] Linux+树莓派3开发总结——cx_Freeze打包Python3程序(工程文件)
  17. 巧妙使用JQuery Clone 添加多行数据,并更新到数据库的实现代码
  18. 19春招多益网络前端笔试题
  19. 多x多y的origin图_3本纯爱文推荐:医疗师 x 小狼狗,漫漫何其多经典
  20. 计算机基础与知识点总结,计算机基础知识点总结

热门文章

  1. LNMP服务器安装配置(Rhel+Nginx+PHP+MySQL)
  2. socket编程资料-网络收集
  3. C# 中是否支持 Like 和 ln 条件的参数化查询 ?
  4. 继 SpringBoot 3.0,Elasticsearch8.0 官宣:拥抱 Java 17
  5. 细聊.NET6 ConfigurationManager的实现
  6. 控制 Redis stream 的消息数量
  7. 【招聘(北京成都)】北森 招聘.NET 架构师工程师
  8. Blazor 路由及导航开发指南
  9. C#-using与添加引用的关系
  10. 通过 GitHub Actions 自动创建 Github Release