ABP领域层知识回顾之---实体
标题:重温ABP领域层
1. 前言
最近一段时间一直在看《ABP的开发指南》(基于DDD的经典分层架构思想)。因为之前一段时间刚看完《领域驱动设计:软件核心复杂性应对之道》,概念比较多,看着有点空。于是拿起了这本书。应该说是不是书, 只是一个PDF版的开发指南。于是乎,就开始了。好了,废话不多说,首先是ABP领域层的结构介绍,如下图所示:
从图中可以看到,ABP的领域层分为 实体,仓储,工作单元,数据过滤器,以及领域事件五个部分。这五个部分的功能作用,如果看过了解过DDD的应该不会陌生。接下来我将一一介绍这五个部分的详情,每个部分具体作用,以及实现。顺便给自己温习温习。附加一点自己粗浅的理解,如有不正确的地方,欢迎指正,交流。
2. 各个模块
2.1 ABP领域层-实体
很多对象不是通过它们的属性定义的,而是通过一连串的连续性事件和标识定义的。———摘录自《领域驱动设计》第5章 5.2 模式:Entity(又称为Reference Object)
在ABP的实体中,实体继承至Entity。可以细分为下面三个部分。1、实体类,2、接口约定以及3、IEntity接口

2.1.1 首先是第一个实体类
查看源码发现如下:
namespace Abp.Domain.Entities
{
/// <summary>
/// A shortcut of <see cref="T:Abp.Domain.Entities.Entity`1" /> for most used primary key type (<see cref="T:System.Int32" />).
/// </summary>
[Serializable]
public abstract class Entity : Entity<int>, IEntity, IEntity<int>
{
}
}
然后最后我们看下IEntity<TPrimary> 之后就真相大白了。
namespace Abp.Domain.Entities
{
/// <summary>
/// Defines interface for base entity type. All entities in the system must implement this interface.
/// </summary>
/// <typeparam name="TPrimaryKey">Type of the primary key of the entity</typeparam>
public interface IEntity<TPrimaryKey>
{
/// <summary>Unique identifier for this entity.</summary>
TPrimaryKey Id { get; set; }
/// <summary>
/// Checks if this entity is transient (not persisted to database and it has not an <see cref="P:Abp.Domain.Entities.IEntity`1.Id" />).
/// </summary>
/// <returns>True, if this entity is transient</returns>
bool IsTransient();
}
}
相当于每个继承于 Entity 的都有一个Id属性。Id属性是该实体的主键,所以,Id是所有继承自Entity类的实体的主键。当然,从源码中,我们可以发现。很显然这个Id数据的类型可以被更改。因为是<TPrimary>类型的,所以,你如果想要改成long,或者Guid等等啦。只需要向如下这样定义:
public class ClassA : Entity<Guid>
{
//...
}
2.1.2 第二个是接口约定
刚开始听到这个名字时,我觉得有点难以理解。但是在文章中,听了一下解释。可以帮助理解,如下:
很多实体会有像
CreationTime用来指示该实体是什么时候被创建的。ABP提供了一些有用的接口来实现类似的功能,只需要实现这些接口的实体,就能够实现指定的功能。
在接口预定中,又分为如下三个部分:

首先是审计(Auditing),这个接口主要的是CreationTime 这个属性。只要实体类实现IHasCreationTime 接口,当该实体被插入到数据库时,ABP会自动设置该属性的值为当前时间。
public interface IHasCreationTime{
DateTime CreationTime{get;set;}
}
审计中还有一个接口ICreationAudited ,这个接口是扩展至IHasCreationTime ,并且该接口还有一个属性CreatorUserId ,可以用来记录当前用户的Id,
public interface ICreationAudited : IHasCreationTime{
long ? CreatorUserId{get;set;}
}
CreationAuditedEntity 类已实现了 ICreationAudited 我们可以直接继承来使用。
审计中还有一个实现类似修改功能的接口IModificationAudited
public interface IModificationAudited{
DateTime? LastModificationTime{get;set;}
ling? LastModifierUserId{get;set;}
}
当然,如果你想都实现这些审计属性,ABP也提供给你了。IAudited 接口。
public interface IAudited : ICreationAudited, IModificationAudited{
}
可能你有点乱了,我来给你理理。大概就是如下这样的。

这样简单吧。
接下来是软删除, 表示标记了一个实体已经被删除了。而不是从数据库中删除记录。对应的接口为ISoftDelete:
public interface ISoftDelete{
bool IsDeleted{get;set;}
}
来源于文中:当一个实现了软删除的实体正在被删除,ABP会察觉到这个动作,并且阻止其删除,设置
IsDeleted属性值为true并且更新数据库中的实体。
和审计中的ICreationAudited类似, 记录谁删除了这个实体。IDeletionAudited 接口。
public interface IDeletionAudited: ISoftDelete{
long? DeleterUserId{get;set;}
DateTime? DeletionTime{get;set;}
}
当然,如果你想要实现所有(包括,创建,修改,和删除。)那就实现这个终极接口, IFullAudited
public interface IFullAudited: IAudited , IDeletionAudited{
//...
}
实体类 FullAuditedEntity 实现了 IFullAudited 接口。可以直接继承使用。
那么审计的终极总结图就如下:

很清楚了吧!
PS:详情可以查看源代码 Abp.Domain.Entities.Auditing
2.1.3最后一个是IEntity接口
在2.1.1 中已经介绍了一下,这里就不赘述。Entity 实现了 IEntity接口(和Entity<TPrimaryKey> 实现了 IEntity<TPrimaryKey> 接口)。
2.2 ABP领域层-仓储
2.3 ABP领域层-工作单元
2.4 ABP领域层-数据过滤器
2.5 ABP领域层-领域事件
3. 结语
本想一次性把这些都总结整理一下,突然发现内容有点多。还是一步一步来,慢慢整理把。这次先整理实体。好尴尬。
4.附录
参考链接:
- https://www.aspnetboilerplate.com/Pages/Documents
- http://www.cnblogs.com/farb/p/ABPTheory.html
- http://www.cnblogs.com/mienreal/p/4528470.html
ABP领域层知识回顾之---实体的更多相关文章
- ABP领域层知识回顾之---仓储
1. 前言 在上一篇博文中 http://www.cnblogs.com/xiyin/p/6810350.html 我们讲到了ABP领域层的实体,这篇博文继续讲ABP的领域层,这篇博文的主题是ABP ...
- ABP领域层知识回顾之---工作单元
1. 前言 在上一篇博文中(http://www.cnblogs.com/xiyin/p/6842958.html) 我们讲到了ABP领域层的仓储.这边博文我们来讲 工作单元.个人觉得比较重要.文 ...
- ABP(现代ASP.NET样板开发框架)系列之10、ABP领域层——实体
点这里进入ABP系列文章总目录 基于DDD的现代ASP.NET开发框架--ABP系列之10.ABP领域层——实体 ABP是“ASP.NET Boilerplate Project (ASP.NET样板 ...
- ABP领域层——实体
ABP领域层——实体 基于DDD的现代ASP.NET开发框架--ABP系列之10.ABP领域层——实体 ABP是“ASP.NET Boilerplate Project (ASP.NET样板项目)”的 ...
- ABP(现代ASP.NET样板开发框架)系列之11、ABP领域层——仓储(Repositories)
点这里进入ABP系列文章总目录 基于DDD的现代ASP.NET开发框架--ABP系列之11.ABP领域层——仓储(Repositories) ABP是“ASP.NET Boilerplate Proj ...
- ABP(现代ASP.NET样板开发框架)系列之12、ABP领域层——工作单元(Unit Of work)
点这里进入ABP系列文章总目录 基于DDD的现代ASP.NET开发框架--ABP系列之12.ABP领域层——工作单元(Unit Of work) ABP是“ASP.NET Boilerplate Pr ...
- ABP(现代ASP.NET样板开发框架)系列之13、ABP领域层——数据过滤器(Data filters)
点这里进入ABP系列文章总目录 基于DDD的现代ASP.NET开发框架--ABP系列之13.ABP领域层——数据过滤器(Data filters) ABP是“ASP.NET Boilerplate P ...
- ABP(现代ASP.NET样板开发框架)系列之14、ABP领域层——领域事件(Domain events)
点这里进入ABP系列文章总目录 基于DDD的现代ASP.NET开发框架--ABP系列之14.ABP领域层——领域事件(Domain events) ABP是“ASP.NET Boilerplate P ...
- ABP领域层——领域事件(Domain events)
ABP领域层——领域事件(Domain events) 基于DDD的现代ASP.NET开发框架--ABP系列之14.ABP领域层——领域事件(Domain events) ABP是“ASP.NET B ...
随机推荐
- Java基础学习笔记二 Java基础语法
注释 注释用来解释和说明程序的文字,注释是不会被执行的. 单行注释 //这是一条单行注释 public int i; 多行注释 /* 这是 * 一段注释, * 它跨越了多个行 */ public vo ...
- 用jQuery.delegate()将事件绑定在父元素上面
1.先看看官方的示例: <html> <head> <script type="text/javascript" src="/jquery/ ...
- Could not create pool connection. The DBMS driver exception was: null, message from server: "Host '192.168.XX.XX' is blocked because of many connection errors; unblock with 'mysqladmin flush-hosts'
早上打开浏览器准备登陆某个系统,发现Error 404--Not Found,有点奇怪,这个服务器应该没人用了才对,然后到weblogic后台去看日志,报如下错误: "Could not c ...
- Beta冲刺合集
Beta冲刺序列: Beta凡事预则立 :Beta No.0 Beta冲刺Day1:Beta No.1 Beta冲刺Day2:Beta No.2 Beta冲刺Day3:Beta No.3 Beta冲刺 ...
- 使用Flask-SQLAlchemy管理数据库
SQLAlchemy 是一个很强大的关系型数据库框架,处于数据库抽象层 ,支持多种数据库后台. 提供了高层 ORM,也提供了使用数据库原生 SQL 的低层功能. 安装Flask-SQLAlchemy ...
- C语言--总结报告
1.当初你是如何做出选择计算机专业的决定的? 经过一个学期,你的看法改变了么,为什么? 你觉得计算机是你喜欢的领域吗,它是你擅长的领域吗? 为什么? 当初填报志愿我是有很明确的专业方向的,就是IT类的 ...
- 敏捷冲刺每日报告——Day2
1.情况简述 Alpha阶段第一次Scrum Meeting 敏捷开发起止时间 2017.10.26 00:00 -- 2017.10.27 00:00 讨论时间地点 2017.10.26晚9:30, ...
- Beta敏捷冲刺每日报告——Day3
1.情况简述 Beta阶段Scrum Meeting 敏捷开发起止时间 2017.11.4 00:00 -- 2017.11.5 00:00 讨论时间地点 2017.11.4 晚9:30,电话会议会议 ...
- 201621123057 《Java程序设计》第4周学习总结
1. 本周学习总结 1.1 写出你认为本周学习中比较重要的知识点关键词 答: (普通方法 / 构造函数)重载. static . final.继承与多态.extends.object类.abstrac ...
- verilog学习笔记(2)_一个小module及其tb
module-ex_cnt module ex_cnt( input wire sclk, input wire rst_n, output wire[9:0] cnt ); reg [9:0] cn ...
