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

Entity Framework を使用して論理的に削除されたエンティティをフィルターで除外するにはどうすればよいですか?

Susan Sarandon
リリース: 2025-01-05 13:52:44
オリジナル
650 人が閲覧しました

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

Entity Framework を使用した論理的に削除されたエンティティのフィルター処理

Entity Framework の既定の動作には、クエリ結果に論理的に削除されたエンティティが含まれます。これらのエンティティを自動的にフィルターで除外するには、次の解決策を検討してください。

解決策: EntityFramework.DynamicFilters

EntityFramework.DynamicFilters ライブラリを利用して、ナビゲーション プロパティなどのクエリにグローバル フィルターを適用します。エンティティに ISoftDelete インターフェイスを実装し、DbContext.OnModelCreating() メソッドでフィルターを定義することにより、論理的に削除されたエンティティをクエリ結果から自動的に除外できます。

modelBuilder.Filter("IsDeleted", (ISoftDelete d) => d.IsDeleted, false);
ログイン後にコピー

このフィルターは、任意のエンティティに where 句を挿入します。 ISoftDelete を実装するエンティティに対してクエリを実行し、削除済みとしてマークされたエンティティを効果的に除外します。

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

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート