图在前
目前项目中可能出现的三种Model
模式,对于我们现在开发的一个项目,我觉得使用DDD
的思想来设计模型比较清晰,使用DDD
的思想把模型model
分成了如下三种:
下面是我微博中的截图:
上面的图中把模型分成了ViewModel
,它与页面相关,DomainModel
,它与业务模块相关,Model
,它与数据库相关,它是对数据表的一种映射,一般用XML来表示。
文字说明在后
下面我们来举个例子,用认识一下这三个模型:
下面以用户业务为例,来讲一个这三种模型
UserDomainModel
public class UserDomainModel
{
[Required]
[Display(Name = "用户名")]
public string UserName { get; set; }
[Required]
[DataType(DataType.EmailAddress)]
[Display(Name = "电子邮件地址")]
public string Email { get; set; }
public int UserID { get; set; }
public Common_Area Common_Area{get;set;}
public User_Extension User_Extension{get;set;}
}
而对于用户业务它又有注册,登陆,这需要不同的view
来呈现,这时需要ViewModel
LoginModel
和RegisterModel
public class LoginModel
{
[Required]
[Display(Name = "用户名")]
public string UserName { get; set; }
[Required]
[DataType(DataType.Password)]
[Display(Name = "密码")]
public string Password { get; set; }
[Display(Name = "记住我?")]
public bool RememberMe { get; set; }
}
public class RegisterModel
{
[Required]
[Display(Name = "用户名")]
public string UserName { get; set; }
[Required]
[StringLength(100, ErrorMessage = "{0} 必须至少包含 {2} 个字符。", MinimumLength = 6)]
[DataType(DataType.Password)]
[Display(Name = "密码")]
public string Password { get; set; }
[DataType(DataType.Password)]
[Display(Name = "确认密码")]
[Compare("Password", ErrorMessage = "密码和确认密码不匹配。")]
public string ConfirmPassword { get; set; }
}
而这些数据如何与数据库关联,这会用到了model
,即我们的表,对于用户业务来说,它可以有user_info,user_Extesion,Common_area
等model
组成,而domain model
是将这三张表进行组合,以user_info
为主导,其它两个表于辅助,形式一个整体,而这个
整体我们在DDD里叫它聚合,整理里的标识叫它聚合根,一般是一个Guid
码。