接着abp vnext2.0核心組件之模塊加載組件源碼解析和abp vnext2.0核心組件之.Net Core默認DI組件切換到AutoFac源碼解析集合.Net Core3.1,基本環境已經完備,接下去就是構建領域層,vnext整個領域層大致分為聚合根、實體、值對象、事件實體、倉儲、服務等等,內容較多,所以我打算分隨筆進行介紹.首先介紹領域實體。注:這邊所說的實體,是abp團隊提供的抽象.如果不了解領域相關的知識,建議閱讀<<領域驅動設計:軟件核心復雜性應對之道>>需要一定設計模式的功底.如果設計模式不了解,請移步本人的設計模式分類.我也是略懂,所以本文有不當之處,請指正!謝謝!另外提一點,貧血的領域模型和充血的領域模型有本質的區別.有興趣的可以研究研究,后續有時間我也會補充隨筆,大家一起來探討.
領域實體分為審計實體和一般實體,如下圖所示
圖中紅框為常用實體抽象,Events中的實體需要配和EventBus事件總線,這一塊作為vnext的單獨組件,后續我會寫一篇文章解析源碼.ok,下面開始講解.
整個實體抽象結構和老版abp沒有什么大的區別.單單從內容看.首先介紹普通實體.分為聚合根和一般實體
1、實體
為什么要先介紹實體,因為聚合根也是一個實體,實體代碼如下:
這邊就很有趣了,很明顯支持復合主鍵的實體.貌似和老版Abp不一樣,記不太清了,一般情況下,復合主鍵的設計也比較少見.單主鍵較多.
再看看泛型實體,主鍵可自行指定
很簡單,這邊說下Equals的邏輯,比較復雜,如下:
這兩個邏輯很簡單,看看就明白了.
接下去判斷實體的主鍵
如果主鍵的值為其類型的默認值,且比較的兩個類型都是如此,那么直接認為兩個實體不相等.
到這里需要理解下這個邏輯,如果兩個實體不為空,且類型一致,且引用不一樣,但是兩個實體的主鍵都為其類型的默認值.則認為兩個實體不相等.
官方解釋是:Transient objects are not considered as equal
接着
兩個類型必須具有類型的IS-a關系或必須是同一類型
接着
如果兩個實體都是租戶實體,且上面的條件都不滿足的情況下,兩個實體的租戶Id不相等,則認為兩個實體不相等.
ok,實體結構到這里解析完畢,比較簡單.
2、聚合根
聚合根本身也屬於一個實體,其結構如下
挑幾個核心接口解析下
每一個聚合根都具有一組方法來操作領域事件,因為領域事件作為vnext單獨組件的存在,所以本文不做解析,后續會有隨筆進行介紹.
接着
每一個聚合根都維護了一個額外屬性的字段,方便進行靈活的擴展.比如和mogodb等庫進行合作.
接着
每一個聚合根都維護着一個並發令牌,初始化聚合根時,直接給一個GUID值,貌似只在EF Core中有效.其他ORM可能需要自行實現(個人理解,如果Dapper支持這種機制,請在評論區告知,萬分感謝)。
當然對應的有一個泛型版本,主鍵可自行指定
ok,整個聚合根的結構也介紹完畢,比較簡單.
3、審計實體 - 創建型實體
(1)、創建型實體
只包含創建功能的常規實體抽象.泛型版本主鍵可自行指定 如下:
整個設計我個人有一個疑問,如下:
主鍵不應當統一嗎?歡迎在評論區討論.
(2)、創建型實體帶創建人抽象
如果當前記錄需要記錄創建人,那么就可以使用這個實體.當然也提供了泛型版本,主鍵可自行指定
4、審計實體 - 創建修改型實體
(1)、創建修改型實體
如果當前實體同時具備創建和修改的功能,那么可以使用如下實體抽象
這里的Guid,依然如此,個人覺得主鍵需統一,泛型版本主鍵可自行指定 如下:
(2)、創建修改型實體呆創建者和修改者
如果當前實體同時具備創建和修改的功能,同時需要記錄創建者和修改者,那么可以使用如下實體抽象
泛型版本,主鍵可自行指定 如下:
5、審計實體 - 創建修改刪除型實體
(1)、創建修改刪除型實體
如果當前記錄具備創建、修改、刪除三大功能,那么可以使用如下實體抽象
泛型版本 主鍵可自行指定 如下:
(2)、創建修改刪除型實體帶創建者和修改者和刪除者
如果當前實體同時具備創建和修改和刪除的功能,同時需要記錄創建者和修改者和刪除者,那么可以使用如下實體抽象
泛型版本 主鍵可自行指定 如下:
6、審計聚合根 - 創建型聚合根
如果當前聚合根具備創建的功能,那么可以使用如下實體抽象
泛型版本 主鍵自行指定如下
因為篇幅問題,聚合根其余的功能就不介紹了,和實體一致.其實本質聚合根就是一個實體.
ok,vnext關於DDD的實體結構架構大致就是如此,很簡單,當然這邊領域事件結構沒有介紹,后續有隨筆會介紹.可以看到,除了主鍵沒有統一.這個設計非常的nice
7、值對象
關於值對象有如下文章
https://docs.microsoft.com/en-us/dotnet/standard/microservices-architecture/microservice-ddd-cqrs-patterns/implement-value-objects
微軟提供的關於值對象的實現思路,abp團隊也是參照此文章實現,其代碼如下:
abp團隊也只是提供了簡單的抽象,代碼也比較簡單,這里就不多說明了.
純屬個人理解,能力有限,有問題請指正!