.NET MVC4 实训记录之三(EntityFramework 与枚举)
EntityFramework对枚举的引入是从版本5开始的(如果没有记错的话)。枚举可以很大程度上提高对程序的可读性。那么在EntityFramework的CodeFirst模式下,如何使用枚举呢?答案很简单:还是那么用!
看似废话,其实不然,看下面(修改上一篇中用户信息定义):
1 /// <summary> 2 /// 性别枚举 3 /// </summary> 4 public enum Gender 5 { 6 Male, 7 Female 8 } 9 10 public class UserProfile 11 { 12 [Key] 13 [DatabaseGenerated(DatabaseGeneratedOption.Identity)] 14 [Column(Order = 0)] 15 public int UserId { get; set; } 16 17 [Column(Order = 1)] 18 [Required] 19 public string UserName { get; set; } 20 21 [Column(Order = 2)] 22 public string UserCode { get; set; } 23 24 [Column(Order = 3)] 25 public int Status { get; set; } 26 27 [Column(Order = 4)] 28 public string Email { get; set; } 29 30 [Column(Order = 5)] 31 public Gender Gender { get; set; } 32 33 [Column(Order = 6)] 34 public int? CreatorId { get; set; } 35 36 public virtual ICollection<Role> Roles { get; set; } 37 38 public int? AddressId { get; set; } 39 40 [ForeignKey("AddressId")] 41 public Address Address { get; set; } 42 43 public UserProfile() 44 { 45 Gender = Framework.DomainModels.Gender.Male; 46 } 47 }
删除旧的数据库,重新运行项目,看看会有什么结果!
好像没什么变化?--------确实没有什么变化!别着急,继续往下看!
在AccountController中新增修改用户的Action,添加用户编辑视图。
/* 加载编辑页面的Action */ public ActionResult EditUser(int id) { var model = BaseService.GetSingle<UserProfile>(id); //按照ID获取用户数据 return View(model); } /* 编辑页面视图 */ @model Framework.DomainModels.UserProfile @{ ViewBag.Title = "EditUser"; } <h2>EditUser</h2> @using (Html.BeginForm()) { @Html.EditorForModel(); }
运行你的项目,输入连接http://localhost:****/Account/EditUser/1看看结果(注意,最后一个1是你已经注册的某个用户的ID,前提是你的路由配置要支持这种访问。其实就是创建项目时的默认路由配置)。
OK,枚举变量名已经显示,并非我们在数据库中看到的Int型的值。EF还是比较聪明的。其实这个字段应该显示为一个下拉列表,而并非文本框才最合理。
一些思考:对于项目而言,并非是所有可以分类的字段都适合使用枚举类型。例如用户状态Status字段,我们可以用数字0表示用未激活,1表用户已激活。为使我们的代码开起来很优雅,然后就用枚举类型描述这个字段。当然这样做没有错,但是如果考虑到扩展性的话,这样做就是一个硬伤。假如我给用户状态增加一个“锁定”,表示用户已经登录,不能再在其它地方登录的话,就必须修改我们的枚举定义。那么这种情况下,建议还是使用普通的Int型(或字符型)字段比较好。虽然我们需要做一些判断将用户可读懂的状态信息显示,但比起修改类型定义带来的好处更多。往后我们还会继续讨论,如何让代码自动识别这些Int型(或字符型)的字段,将可读性更高的信息展示给用户(我自己都很期待噢)。