EF Core – Soft Delete 实现

前言

在 SQL Server – Soft Delete 中, 讲到了如果在 SQL Server 实现 Soft Delete.

这篇来说说, EF Core 在中间扮演的角色.

 

主要参考

Entity Framework Core: Soft Delete using Query Filters

Soft delete and unique constraint

Using Unique Database Fields with Soft Deletes

 

Global Filter

通过 Global Filter 可以帮助我们写一堆的 where DateDeleted != null 的语句.

EF 很聪明的哦, Include 也会加上这些语句的. 根本就是为了 soft delete 而实现的功能嘛.

 

Intercept SaveChanges

通过 Intercept SaveChanges, 判断 entity entry state = delete, 然后转成 update deleted = true 也是一个不错的手法. 

 

Custom Migrations

实现 Soft Delete 需要许多的 trigger 帮忙, 这时就需要 custom migrations 来帮助管理 trigger 的代码了. 

 

posted @   兴杰  阅读(166)  评论(0编辑  收藏  举报
编辑推荐:
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
阅读排行:
· 百万级群聊的设计实践
· 永远不要相信用户的输入:从 SQL 注入攻防看输入验证的重要性
· 全网最简单!3分钟用满血DeepSeek R1开发一款AI智能客服,零代码轻松接入微信、公众号、小程
· .NET 10 首个预览版发布,跨平台开发与性能全面提升
· 《HelloGitHub》第 107 期
点击右上角即可分享
微信分享提示