博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Rafy 框架 - 幽灵插件(假删除)
阅读量:6991 次
发布时间:2019-06-27

本文共 2066 字,大约阅读时间需要 6 分钟。

08104816-68bbd9d568c049c08150b6cc83d1ac15.gif

 

Rafy 框架又添新成员:幽灵插件。本文将解释该插件的场景、使用方法、原理。

 

场景


在开发各类数据库应用系统时,往往需要在删除数据时不是真正地删除数据,而只是把数据标识为‘已删除’状态。这些数据在业务逻辑上是已经完全删除、不可用的数据,但是不能在数据库中真正的把它们删除,而是需要永久保留这些历史数据。即开发人员常说的‘假删除’功能。

这种需求往往是系统级的。往往不是针对某一张表,而很可能是针对系统中的所有表都需要实现‘假删除’功能。

 

使用方法


由于这种需求比较常见,所以我们决定专门为该功能写一个独立的 Rafy 插件。这样,开发人员需要实现假删除功能时,只需要引用该插件后,系统中所有删除的实体都自动变为‘幽灵’,同时这些幽灵数据在仓库的所有查询中都将被自动过滤。

使用步骤:

  1. 通过 Nuget Package Manager 搜索并安装 Rafy.Domain.EntityPhantom 插件。
  2. 在 DomainApp 中添加该插件:
    class JXCApp : DomainApp{    protected override void InitEnvironment()    {        //添加幽灵插件到 Rafy 应用程序集中。        RafyEnvironment.DomainPlugins.Add(new Rafy.Domain.EntityPhantom.EntityPhantomPlugin());        RafyEnvironment.DomainPlugins.Add(new JXCPlugin());        base.InitEnvironment();    }}
  3. 为需要幽灵功能的实体打开该功能,需要在实体元数据配置中进行配置:
    internal class UserConfig : JXCEntityConfig
    { protected override void ConfigMeta() { Meta.MapTable().MapAllProperties(); //在实体配置中加入此行代码,为实体启用幽灵功能。 Meta.EnablePhantoms(); }}

 

效果


所有继承自 Entity 的实体都会统一的添加一个 IsPhantom 的属性。这个属性表示这个实体是否为‘幽灵’,即已经删除的数据。

  • 开发者可以使用 Meta.EnablePhantoms() 来为某个指定的实体类型开启‘幽灵’功能。
  • 开启该功能的实体的 IsPhantom 属性会自动映射到数据库中。
  • 在保存实体时,如果要删除一个聚合实体,则这个聚合中的所有实体都将会被标记为‘幽灵’状态。
  • 在查询实体时,所有的查询,都将会自动过滤掉所有‘幽灵’状态的数据。(手写 SQL 查询的场景不在考虑范围内。)
  • 使用批量导入数据插件进行数据的批量导入时,批量删除的实体同样都会被标记为‘幽灵’状态。

运行程序后,数据库中的字段,已经自动添加上 IsPhantom 字段了:

在使用 GetAll 查询所有实体时,框架自动加上一 IsPhantom = false 的过滤条件:

SELECT *FROM [User]WHERE [User].[IsPhantom] = @p0ORDER BY [User].[Id] ASCParameters:False

数据的删除,变为更新表中对应行的 IsPhantom 字段为 True:

UPDATE [User] SET [Name] = @p0,[IsPhantom] = @p1 WHERE [Id] = @p2Parameters:"Name",True,3

 

原理


幽灵插件的原理比较简单。在 Rafy 框架的基础上,以插件的形式对 Rafy 框架中实体的数据层进行了扩展。在启用实体的幽灵功能后,该实体的 DataProvider 类型的 Deleting、Querying 事件都会被监听并扩展:

/// /// 数据的删除、查询的拦截器。/// internal static class PhantomDataInterceptor{    internal static void Intercept()    {        RepositoryDataProvider.Deleting += RepositoryDataProvider_Deleting;        RepositoryDataProvider.Querying += RepositoryDataProvider_Querying;    }}

在查询时,框架自动分析出当前查询的 SQL 树,并在主查询上加上 IsPhantom = false 的过滤条件。

有兴趣的同学,可以查看 Rafy 框架源码。微笑

 

PS:该文已经纳入《 》中。

转载地址:http://okzvl.baihongyu.com/

你可能感兴趣的文章
linux基础(day 33)
查看>>
12.6 Nginx安装 12.7 默认虚拟主机 12.8 Nginx用户认证 12.9 Nginx域名重定向
查看>>
MaxCompute Studio 使用入门
查看>>
linux进程介绍
查看>>
nginx服务器出现504 gateway time-out怎么解决
查看>>
Java-实现链表的基本操作
查看>>
Eclipse Platform 4.3.1.M20130814-0800
查看>>
MapReduce函数的JavaScript模拟实现
查看>>
在cs后台获取前台datalist控件里的其他控件
查看>>
100-50
查看>>
eclipse 新增代码补全
查看>>
EBS 用户职责 不显示
查看>>
前嗅ForeSpider脚本教程:频道脚本使用场景及配置关键词搜索
查看>>
SAMBA
查看>>
pfSense 配置Snort(包含OpenApp ID)
查看>>
wifi 调试android设备
查看>>
虚拟机 ----最小安装无法使用vim编辑器
查看>>
Zookeeper 安装笔记
查看>>
Python 拷贝 copy
查看>>
The NoSQL System
查看>>