EF DataBase First生成model的验证

时间:2021-06-07 08:32:23

如何避免在EF自动生成的model中的DataAnnotation被覆盖掉

相信很多人刚接触EF+MVC的时候,DataBase First模式生成model类中加验证信息的时候,会在重新生成model的时候被重写掉。
这里介绍一个方法:
比如我有个Book类是从数据库中生成到model中的,我们可以在Models文件夹中创建一个局部类名称与Book类同名(注意:该类的命名空间必须与自动生 
成的类属于同一个命名空间),类内容为空的就可以,然后在新建的部分类下方再创建一个类(BookMetaData),类中中加上我们需要验证的列与验证信 
息,然后需要将
[MetadataType(typeof(BookMetaData))]加在新建的Book类名上方
这时我们在view页面中不用更改代码。这样当我们重新生成model的时候,我们自己定义的部分类Book就不会受影响了。

解决方案:

EF DataBase First生成model的验证

说明:Model1.edmx是ef生成的,Book.cs是我额外添加的,代码在如下

Model代码:

 1 using System;
2 using System.Collections.Generic;
3 using System.Linq;
4 using System.Web;
5 using System.ComponentModel.DataAnnotations;
6
7 namespace Web.Models
8 {
9 [MetadataType(typeof(BookMetadata))]
10 public partial class Book
11 {
12 class BookMetadata
13 {
14 [Display(Name = "名称")]
15 [Required(ErrorMessage = "名称不能为空")]
16 public string name { get; set; }
17
18 [Required(ErrorMessage = "价格不能为空")]
19 [Range(5, 100, ErrorMessage = "价格5-100之间")]
20 public decimal price { get; set; }
21
22 public decimal time { get; set; }
23 }
24 }
25 }

控制器代码:

Controllers中BookController.cs的Add方法代码如下

public ActionResult Add()
{
return View();
}
[HttpPost]
public ActionResult Add(Book model)
{
if (ModelState.IsValid)
{
db.Book.AddObject(model);
int res = db.SaveChanges();
ViewData["status"] = "成功:" + DateTime.Now.ToString();
}
else {
ViewData["status"] = "失败:" + DateTime.Now.ToString();
}
return View();
}

运行效果截图:

EF DataBase First生成model的验证

测试环境:VS2010+.Net4.0+MVC4+EF4