在FreeSQL中实现「触发器」和软删除功能

前言最近做新项目 , 技术栈 AspNetCore + FreeSQL
这个ORM真的好用 , 文档也很完善 , 这里记录一下两个有关「触发器」的功能实现
修改实体时记录更新时间模型代码
【在FreeSQL中实现「触发器」和软删除功能】我的模型都是基于这个 ModelBase 派生的 , 自带三个属性字段
public abstract class ModelBase : ISoftDelete {public DateTime CreatedTime { get; set; } = DateTime.Now;public DateTime ModifiedTime { get; set; } = DateTime.Now;public bool IsDeleted { get; set; } = false;}现在要实现修改每个实体的时候自动更新 ModifiedTime 字段
可以使用 FreeSQL 提供的 AOP 里的「审计属性值」功能

按照官方的介绍:该功能可以实现插入/更新时统一处理某些值 , 比如某属性的雪花算法值、创建时间值、甚至是业务值 。
创建FreeSQL实例的时候配置一下
检查实体类型 , 如果是 ModelBase 类型的话 , 那么把 ModifiedTime 字段设置为当前修改的时间
// 实体变化事件监听freeSql.Aop.AuditValue += (sender, args) => {if (args.Object is ModelBase modelBase) {modelBase.ModifiedTime = DateTime.Now;}};除此之外 , 还有一个功能是监控实体修改的 , 我一开始用的这个 , 但是发现它是在实体已经修改保存完才执行 , 无法实现记录更新时间的功能 。不过这个用来审计是比较有用的 , 记录一下~
fsql.Aop.CurdAfter += (s, e) => {Console.WriteLine($"ManagedThreadId:{Thread.CurrentThread.ManagedThreadId};"+$" FullName:{e.EntityType.FullName} ElapsedMilliseconds:{e.ElapsedMilliseconds}ms, {e.Sql}");};实现软删除现在的设计为了提高容错性都是做软删除 , 这样误删之后还能恢复数据 。
我之前封装的 DjangoStarter 框架是自己实现了软删除(通过重写 DjangoORM 的 objects 管理器实现)
来到 FreeSQL 这里 , 根据官方文档 , 可以直接使用过滤器功能实现软删除 。
先定义一个接口
public interface ISoftDelete {bool IsDeleted { get; set; }}其实用我上面的 ModelBase 也行
不过我看官方文档这么用了 , 也就跟着写~ (接口的泛用性更高 , 可能有些实体是不需要创建时间和修改时间字段的)
然后在创建FreeSQL实例的时候配置一下
freeSql.GlobalFilter.Apply<ISoftDelete>("IsDeleted", a => a.IsDeleted == false);这样读取数据的时候 , IsDeleted 字段为 true 的项目就自动过滤掉了
删除的时候不要直接执行 repo.Delete  , 而是把 IsDeleted 字段设置为 true
当然也可以像上面的 AOP 一样 , 把所有删除操作拦截下来 。
参考资料
  • FreeSQL文档 - AOP - https://freesql.net/guide/aop.html
  • FreeSQL文档 - 过滤器 - https://freesql.net/guide/filters.html

    经验总结扩展阅读