回到目錄html
對於一個聚合來講,它可能會被附加不少事件,這裏咱們叫它領域事務,由於一個聚會咱們能夠把它理解成一個領域,一個業務。對於領域事件不清楚的同窗能夠看看個人這篇文章《DDD~領域事件與事件總線》,裏面有詳細的說明,今天主要說一下領域裏的事務,即領域事件的數據處理和主邏輯裏的數據處理在同一事務裏完成。服務器
SQL2005環境使用TransactionScopeNoMsdtc事務,它是佔佔開發的,原理是將一批操做包裹到一個SqlConnection裏,由開發者維護接連的關閉,這也是使用時要特別注意的地方,由於若是不關閉鏈接,SQL連接池會益出。架構
SQL2008環境使用微軟本身的分佈式事務實現TransactionScope,它對於同一個上下文來講,是不會被提高爲分佈式事務的,這一點對SQL2005要強不少。分佈式
/// <summary> /// 添加WebSystem表時,所須要的事件對象 /// </summary> [Serializable] public class WebSystemCreateEvent : EventBase { /// <summary> /// 數據上下文,它與架構無關,能夠是Linq2Sql,EF,ADO.NET /// </summary> public IUnitOfWork UnitOfWork { get; set; } /// <summary> /// 對象主鍵 /// </summary> public int ID { get; set; } }
[HttpPost] public ActionResult WebSystem(FormCollection form) { //訂閱領域事件 EventBus.Instance.Subscribe<WebSystemCreateEvent>(i => { var entity1 = new DbContextRepository<WebSystem>(i.UnitOfWork).Find(i.ID); entity1.WebSystemName = entity1.WebSystemName + "更新了"; new DbContextRepository<WebSystem>(i.UnitOfWork).Update(entity1); }); IUnitOfWork UnitOfWork = new backgroundEntities1(); var db = new DbContextRepository<WebSystem>(UnitOfWork); using (TransactionScope trans = new TransactionScope()) { var entity = new WebSystem { Info = form["Info"], Status = Convert.ToInt32(form["Status"]), WebSystemName = form["WebSystemName"] }; db.Insert(entity); //發佈領域事務 EventBus.Instance.Publish(new WebSystemCreateEvent { ID = entity.WebSystemID, UnitOfWork = UnitOfWork, }); trans.Complete(); } return RedirectToAction("WebSystemList"); }
TransactionScope截圖post
本地WWW網站服務器的MSDTC爲禁用狀態網站
回到目錄url