ホームページ >バックエンド開発 >C++ >Entity Framework で論理的に削除されたエンティティを自動的に除外するにはどうすればよいですか?

Entity Framework で論理的に削除されたエンティティを自動的に除外するにはどうすればよいですか?

Linda Hamilton
Linda Hamiltonオリジナル
2024-12-31 07:25:10622ブラウズ

How Can I Automatically Filter Out Soft-Deleted Entities in Entity Framework?

Entity Framework での論理的に削除されたエンティティの自動フィルター処理

Entity Framework Code First を使用する場合、「論理的な削除」は一般的な方法です。実際にデータベースからエンティティを削除せずに、エンティティを削除済みとしてマークできるようにします。このアプローチでは、非アクティブなエンティティをクエリから論理的に除外しながら、履歴データを維持します。

質問で示されているように、論理的な削除を実現するには、DbContext の SaveChanges メソッドにカスタム ロジックを実装できます。これにより、エンティティは ISoftDelete インターフェイスを実装し、エンティティに削除済みとしてマークを付ける「Delete」メソッドが確保されます。

論理的に削除されたエンティティの取得の自動化

ただし、さらに疑問が生じます。データを取得するときに、論理的に削除されたエンティティを自動的に無視する方法を尋ねます。解決策は、関連するすべてのクエリに自動的に適用されるグローバル フィルターを作成するエレガントな方法を提供するライブラリである Entity Framework Dynamic Filters を使用することです。

EntityFramework.DynamicFilters の実装

この機能を実装するには、次の手順に従ってください手順:

  1. NuGet から EntityFramework.DynamicFilters パッケージをインストールします。
  2. DbContext クラスの OnModelCreating メソッドをオーバーライドし、Filter メソッドを呼び出します。
  3. フィルター名を指定します、フィルター条件を表すラムダ式、フィルターが有効になっているかどうかを示すフラグ

たとえば、「IsDeleted」フィルターの場合:

modelBuilder.Filter("IsDeleted", (ISoftDelete d) => d.IsDeleted, false);

使用法

フィルターが定義されると、すべてISoftDelete インターフェイスを実装するエンティティに対するクエリには、where 句「where IsDeleted = false」が自動的に含まれます。これにより、追加のコードを必要とせずに、論理的に削除されたエンティティが結果セットから透過的に除外されます。

EntityFramework.DynamicFilters によって提供される Filter メソッドは、複雑なフィルター条件をサポートしており、ナビゲーション プロパティにも適用できます。このライブラリを利用することで、開発者は論理的な削除の柔軟性を維持しながら、データの取得を簡素化できます。

以上がEntity Framework で論理的に削除されたエンティティを自動的に除外するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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