Rafy 框架 - 时间戳插件

img

本文将解释 Rafy 框架中的时间戳插件的场景、使用方法、原理。git

场景

在开发各种数据库应用系统时,业务领域实体每每须要包含“建立时间”、“最后更新时间”、“建立人”、“最后更新人”等跟踪戳属性。这些属性是领域实体的基本属性,几乎全部的领域业务操做都会使用到这些属性,如:建立业务数据确定会保存建立时间、建立人;更新业务数据须要记录最后更新时间;查询业务数据须要显示建立人等。github

时间戳插件能够自动在数据层维护这些属性,使开发人员专一与业务逻辑开发,减小业务无关基本操做所占用的时间。数据库

使用方法

开发人员在业务领域实体实现时间戳功能时,只须要引用该插件。引用后系统中全部实体都会自动添加时间戳属性,同时仓库中全部数据库操做都会增长时间戳属性。框架

步骤ide

  1. 经过 Nuget Package Manager 搜索并安装 Rafy.Domain.Stamp 插件。
    插件

  2. 在 DomainApp 中添加该插件:
class JXCApp : DomainApp
{
    protected override void InitEnvironment()
    {
        //添加时间戳插件到 Rafy 应用程序集中。
        RafyEnvironment.DomainPlugins.Add(new Rafy.Domain.Stamp.StampPlugin());
        RafyEnvironment.DomainPlugins.Add(new JXCPlugin());

        base.InitEnvironment();
    }
}

添加时间戳插件后,默认全部实体自动注册时间跟踪戳属性。code

效果

通过上面两步设置,User 实体类就已经开启了时间戳跟踪功能,并对实体会有如下的影响:blog

  • 全部继承自 Entity 的实体都会统一添加四个跟踪戳字段。
    运行程序后,数据库中的字段,已经自动添加上跟踪戳字段了:
    继承

  • 执行保存实体时,框架自动给跟踪戳字段赋值。
INSERT INTO 
    [User] ([CreatedTime],[CreatedUser],[UpdatedTime],[UpdatedUser],[CreateTime],[Name]) 
VALUES 
    ('2016-07-18 15:14:45','','2016-07-18 15:14:45','','2000-01-01 00:00:00','用户1')

在用户已登陆的状况下,Rafy会从前上下文中获取当前用户身份,并给CreatedUser、UpdatedUser字段赋值开发

原理

在 Rafy 框架的基础上,以插件的形式对 Rafy 框架中实体的数据层进行了扩展。在Rafy运行环境中加入时间戳插件后,领域中的全部实体默认注册四个跟踪戳属性;同时数据层拦截的提交操做,在添加、更新实体时,设置实体的跟踪戳。

/// <summary>
/// 拦截数据层的提交操做。在添加、更新实体时,设置实体的跟踪戳。
/// </summary>
public class StampSubmitInterceptor : SubmitInterceptor
{
    /// <summary>
    /// 提交指定的实体,并在添加、更新实体时,设置实体的跟踪戳。
    /// </summary>
    /// <param name="e">The e.</param>
    /// <param name="link">The link.</param>
    protected override void Submit(SubmitArgs e, ISubmitInterceptorLink link)
    {
        //...
        ResetStamp(e);
        //...
    }
    internal static void ResetStamp(SubmitArgs e)
    {
        ...
        switch (e.Action)
        {
            //...
            case SubmitAction.Update:
                var entity = e.Entity;
                entity.SetUpdatedTime(DateTime.Now);
                var user1 = RafyEnvironment.Identity;
                entity.SetUpdatedUser(user1.Name);
                break;
            case SubmitAction.Insert:
                var entity2 = e.Entity;
                var now = DateTime.Now;
                entity2.SetUpdatedTime(now);
                entity2.SetCreatedTime(now);
                var user2 = RafyEnvironment.Identity;
                entity2.SetUpdatedUser(user2.Name);
                entity2.SetCreatedUser(user2.Name);
                break;
            //...
        }
    }
}

PS:该文已经归入《Rafy 用户手册》中。

相关文章
相关标签/搜索