ホームページ  >  記事  >  バックエンド開発  >  EF Core 2.0の新機能

EF Core 2.0の新機能

大家讲道理
大家讲道理オリジナル
2017-05-31 14:39:042119ブラウズ




前書き

現在、EF Core の最新バージョンは 2.0.0-priview1-final であるため、この記事では主にこのバージョンのいくつかの手順について説明します。 2.0.0-priview1-final,所以本篇文章主要是针对此版本的一些说明。

注意:如果你要在Visual Studio 中使用 .NET Core 2.0 , 你需要至少 Visual Studio 2017 15.3 预览版本。

相关mysql视频教程推荐:《mysql教程

安装或升级到 EF Core 2.0

你可以通过以下命令来安装或者升级你目前的 .NET Core 版本。

// 安装
PM> install-package Microsoft.EntityFrameworkCore.SqlServer -Pre -Version 2.0.0-preview1-final

// 升级
PM> update-package Microsoft.EntityFrameworkCore.SqlServer -Pre -Version 2.0.0-preview1-final

工具包

// 直接修改 CSPROJ 文件
<ItemGroup>
   <DotNetCliToolReference Include="Microsoft.EntityFrameworkCore.Tools.DotNet" 
       Version="2.0.0-preview1-final" />
</ItemGroup>

// 或者通过以下命令
PM> update-package Microsoft.EntityFrameworkCore.Tools -Pre -Version 2.0.0-preview1-final

EF Core 2.0 新功能

改进的 LINQ 翻译

  • 避免创建不必要的子查询

  • 一些命令将切换到客户端进行执行

  • 只有少数请求才会检索表的所有列

  • 有事没有适当的过滤条件,将单个LINQ 查询转换为 N + 1 查询。

EF.Functions.Like()

在 EF Core 2.0 中添加了 EF.Functions 属性,EF Core Provider 可以使用它们来自定义一些映射到数据库函数后者运算符的方法,以便于在 LINQ 查询中调用它们。如:

var aCustomers =
    from c in context.Customers
    where EF.Functions.Like(c.Name, "a%");
    select c;

分离实体和表

分离实体和表什么意思呢?在以前,一个数据库表会映射到 EF 中的一个实体对象,也就是表和实体是一一对应的关系。那么在 2.0 版本中,允许映射一些关联的实体到一个表中,并且EF会维护这些实例或者引用关系。

modelBuilder.Entity<Customer>()
    .OwnsOne(c => c.WorkAddress);public class Customer
{    public int CustomerId { get; set; }    public Address WorkAddress { get; set; }
}public class Address
{    public string Line { get; set; }    public string PostalOrZipCode { get; set; }    public string StateOrProvince { get; set; }    public string CityOrTown { get; internal set; }
}

在生成数据库表的时候,CustomerAddress 将生成为一个表。

注意:priview1 中此功能暂不完整。

全局查询过滤

新版本引入了一个叫做“垂直过滤”的一个功能,这是一个比较常见的需求。

在我们定义EF Core上下文模型的时候,可以在模型创建的时候附加一些过滤条件,比如在查询的时候总是过滤掉一些“逻辑删除”的数据。

public class BloggingContext : DbContext
{
    public DbSet<Blog> Blogs { get; set; }
    public DbSet<Post> Posts { get; set; }

    public int TenantId {get; set; }

    protected override void OnModelCreating(ModelBuilder modelBuilder)
    {
        modelBuilder.Entity<Post>()
            .HasQueryFilter(p => !p.IsDeleted &&
                  p.TenantId == this.TenantId );
    }
}

当通过直接查询或者导航属性(Include())查询类型数据时,将会自动应用此过滤条件。当然你可以使用 IgnoreQueryFilters()

注: Visual Studio で .NET Core 2.0 を使用する場合は、少なくとも Visual Studio 2017 15.3 プレビュー バージョンが必要です。

推奨される mysql ビデオ チュートリアル: "mysql チュートリアル"

インストールまたはアップグレードEF Core 2.0 へ

次のコマンドを使用して、現在の .NET Core バージョンをインストールまたはアップグレードできます。

services.AddDbContextPool<BloggingContext>(
    options => options.UseSqlServer(connectionString));

ツールキット

private static Func<CustomerContext, int, Customer> _customerById =
    EF.CompileQuery((CustomerContext db, int id) =>
        db.Customers
            .Include(c => c.Address)
            .Single(c => c.Id == id));

...using (var db = new CustomerContext())
{   var customer = _customerById(db, 147);
}

EF Core 2.0の新機能

LINQ変換の改善

  • 不必要なサブクエリの作成を避ける

  • 一部のコマンドは、実行のためにクライアントに切り替えます

  • テーブルのすべての列を取得できるのは少数のリクエストだけです

  • 適切なフィルター条件なしで単一の LINQ クエリが実行される場合があります N に変換します+1 クエリ。

EF.Functions.Like()

EF Core 2.0 に EF.Functions プロパティが追加されました。EF Core Provider はそれらを使用して、データベース関数と後者の演算子にマップするいくつかのメソッドをカスタマイズできます。これらは LINQ クエリで呼び出すことができます。例:
rrreee

エンティティとテーブルを分離する


エンティティとテーブルを分離するとはどういう意味ですか?以前は、データベース テーブルは EF のエンティティ オブジェクトにマップされていました。つまり、テーブルとエンティティの間には 1 対 1 の対応関係がありました。その後、バージョン 2.0 では、いくつかの関連エンティティをテーブルにマップすることが許可され、EF はこれらのインスタンスまたは参照関係を維持します。

rrreee

データベーステーブルを生成する際、CustomerAddress が 1 つのテーブルとして生成されます。

注: 権限 1 のこの機能はまだ完了していません。

グローバルクエリフィルタリング🎜🎜 新しいバージョンでは、比較的一般的な要件である「垂直フィルタリング」と呼ばれる機能が導入されています。 🎜🎜EF Core コンテキスト モデルを定義する場合、クエリ時に一部の「論理的に削除された」データを常にフィルターするなど、モデルの作成時にいくつかのフィルター条件を追加できます。 🎜rrreee🎜このフィルター条件は、直接クエリまたはナビゲーション プロパティ (Include()) を通じて型データをクエリするときに自動的に適用されます。もちろん、 IgnoreQueryFilters() を使用して、クエリ内でこのグローバル フィルターを無効にすることができます。 🎜🎜DbContext 接続プール🎜🎜通常、ASP.NET Core で EF Core を使用するには、DbContext のカスタマイズが含まれます。DbContext はシステム コンテナーに挿入され、コントローラーのコンストラクターを通じてコン​​テナーからオブジェクト インスタンスが取得されます。これは、🎜リクエストごと🎜に新しいインスタンスが作成されることを意味します。 🎜🎜 EF Core 2.0 では、カスタム DbContext を注入する新しい方法が導入され、インスタンス プールを明示的に使用してコンテナーに注入します。 🎜rrreee🎜このメソッドを使用すると、コントローラーが DbContext インスタンスをリクエストすると、まずプール内に使用可能なインスタンスがあるかどうかが確認され、リクエストが処理されると、インスタンスに関連付けられている状態がすべてリセットされ、その後インスタンスがリセットされます。プールに戻ります。 🎜🎜この概念は ADO.NET のデータベース接続プールに似ており、DbContext インスタンスの初期化コストを節約できるという利点があります。多くの ASP.NET Core アプリケーションは、このアプローチを使用してパフォーマンスを向上させることができます。 🎜🎜クエリを手動でコンパイルする🎜🎜 EF と Linq to SQL の以前のバージョンには、クエリを手動または明示的にコンパイルするための API があり、アプリケーションは変換されたクエリをキャッシュして、クエリを 1 回だけコンパイルして複数回実行することができました。 -レート。 🎜🎜EF Core はクエリ式に基づいてクエリを自動的にコンパイルしてキャッシュできますが、このメカニズムではハッシュ計算やキャッシュをバイパスすることでクエリのパフォーマンスが若干向上します。これにより、アプリケーションは Inquire 呼び出しを通じてコン​​パイルされたデリゲート チェーンを使用できるようになります。 🎜rrreee🎜その他🎜🎜EF Core 2.0 では、一部のログ記録と診断インフラストラクチャに大きな調整が加えられ、Azure Application Insights との統合も行われます。 🎜🎜遅延読み込みの追加はまだ議論中であり、この機能は EF Core 2.1 に追加される可能性があります。 🎜🎜🎜🎜🎜🎜🎜🎜🎜🎜🎜🎜

以上がEF Core 2.0の新機能の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。