ef core实现软删除

简介: ef core实现软删除

很多web程序一般的偶不会设计真的物理删除了。

基本上都是在在数据库加一个标记,就得当作已经删除了。同时在查询的时候,过滤已经标记删除的数据

ef core实现软删除是非常简单的,直接在OnModelCreating动态创建一个IsDeleted字段,bool类型。然后扔到ef core的查询过滤器里面去。

protected override void OnModelCreating(ModelBuilder modelBuilder)
        {
            foreach (var entityType in modelBuilder.Model.GetEntityTypes())
            {
                entityType.GetOrAddProperty("IsDeleted", typeof(bool));
                var parameter = Expression.Parameter(entityType.ClrType);
                var propertyMethodInfo = typeof(EF).GetMethod("Property").MakeGenericMethod(typeof(bool));
                var isDeletedProperty = Expression.Call(propertyMethodInfo, parameter, Expression.Constant("IsDeleted"));
                BinaryExpression compareExpression = Expression.MakeBinary(ExpressionType.Equal, isDeletedProperty, Expression.Constant(false));
                var lambda = Expression.Lambda(compareExpression, parameter);
                modelBuilder.Entity(entityType.ClrType).HasQueryFilter(lambda);
            }
        }

然后再保存的时候,扫描实体更改,把状态为Deleted的实体的状态修改为Modified,加上一个IsDeleted的字段,值为false。

ChangeTracker.DetectChanges();
            foreach (var item in ChangeTracker.Entries().Where(e => e.State == EntityState.Deleted))
            {
                item.State = EntityState.Modified;
                item.CurrentValues["IsDeleted"] = true;
            }

这样可以做到在EF中无感知软删除了!

如果需要在查询中查询出已经软删除的数据,直接加上

IgnoreQueryFilters 就行了

blogs = db.Blogs
    .Include(b => b.Posts)
    .IgnoreQueryFilters()
    .ToList();

这样就会把软删除的数据都查询出来。

目录
相关文章
|
数据库 C++
.NET Core 使用 EF 出错的解决方法
.NET Core 使用 EF 出错的解决方法
490 0
.NET Core 使用 EF 出错的解决方法
|
5月前
|
存储 运维 监控
基于EF Core存储的Serilog持久化服务
【7月更文挑战第5天】EF Core 和 Serilog 整合实现日志持久化\n通过 EF Core ORM 将 Serilog 日志记录存储到数据库,提供灵活的日志管理。步骤包括:配置 EF Core 数据库上下文(定义 `LogEntry` 实体,设置数据库连接)、配置 Serilog(指定 EF Core 接收器,定义日志格式和过滤规则)、实现 EF Core 接收器(转换日志事件为实体并保存)。示例中,`LogEntry` 类包含日志信息,`LogDbContext` 用于数据库交互,Serilog 使用 `EfCoreSink` 将日志写入数据库,便于后期查询和分析。
|
4月前
|
程序员 数据库
分享 2 个 .NET EF 6 只更新某些字段的方法
分享 2 个 .NET EF 6 只更新某些字段的方法
117 0
|
4月前
|
SQL 程序员 数据库
总结查看 .NET EF 生成的 SQL 的 3 种方式,亲测可用
总结查看 .NET EF 生成的 SQL 的 3 种方式,亲测可用
134 0
|
4月前
|
SQL 关系型数据库 数据库
EF Core连接PostgreSQL数据库
EF Core连接PostgreSQL数据库
66 0
|
关系型数据库 MySQL 数据库
EF Core反向工程
EF Core反向工程,数据库创建表使用命令生成上下文
103 0
|
开发框架 JavaScript .NET
.NET 8 候选版本 2 (RC2) 现已可用
.NET 8 候选版本 2 (RC2) 现已可用
109 0
.NET 8 候选版本 2 (RC2) 现已可用
【Magisk模块】HC优化4.22 [重置]代号DC
【Magisk模块】HC优化4.22 [重置]代号DC
171 0
【Magisk模块】HC优化4.22 [重置]代号DC
|
存储 Java Linux
【Linux】基础IO --- 系统级文件接口、文件描述符表、文件控制块、fd分配规则、重定向…
【Linux】基础IO --- 系统级文件接口、文件描述符表、文件控制块、fd分配规则、重定向…
|
SQL 存储 数据处理
5.1EF Core原理
对普通集合使用where等方法查询出来的返回值为IEnumerable类型 但是对DbSet使用用where等方法出查询出来的返回值为IQueryable类型
149 0

热门文章

最新文章