MVC自学系列之四(MVC模型-Models)

ASP.NET MVC 提供了一系列工具和特性去使用仅仅定义的对象模型。你可以坐下来好好思考你将要解决的问题,并且写好C#类,当你准备好时就可以使用MVC提供的工具去为每一个实体构建标准的index、create、edit、delete方法,这个构建的工作就称为“基架”(Scaffloding)。

所谓“基架”就是MVC提供的能够在应用程序中产生你所需要的增删改查(CURD)的基础功能的模板代码。

EF

1、通过EF(EninityFramework),开发人员可以使用model-first、schema-first、code-first几种模式。

2、code-first的约定

①如果你想要在数据库中存储类型为A的实体对象,EF会认为你想要在数据库中创建一个名为A的表。如果你的对象中有一个属性名为ID,那EF会把这个ID属性作为表A的主键并且是自动增长的。EF还有一些外键关系、数据库名等等,这些约定代替了你过去在ORM框架中的映射和配置。如果你需要使用已存在的数据库,那么你可能需要提供映射元数据。

②使用EF的code-first,到达数据库的途径就是让你的类继承自DbContext类,这样继承类就将会有一个或多个DbSet<T>类型的属性,每一T代表着你想要保存的类型。

③加载相关联对象--延迟加载

public ViewResult Index()
   {
       var albums = db.Albums.Include(a => a.Genre).Include(a => a.Artist);
       return View(albums.ToList());
   }

     在Index中的Include方法使用即时加载模式去加载与album对象相关联的atrist和genre信息。即时加载模式试图通过使用单一查询去加载所有的数据。

    另一种策略是EF的延时加载模式,EF仅加载LINQ语句中的主要对象(album),而不会加载相关联的属性Genre和Artist,直到需要使用它们的时候才进行加载。但是对于去加载album信息,延时加载会进行多一次的查询,比如有100条album信息,却要进行101次的查询,这就是人们所谓的N+1问题,当使用ORM框架时这是需要面对的问题,延时加载很方便,但是有潜在的额外消耗。

3.用EF生成数据库

①EF的code-first方式尽可能得采用约定大于配置的方针,如果你不去配置从模型到数据库表、列特定的映射,那么EF就用约定去创建数据库表;如果你不想配置特殊的数据库连接,EF会采用约定的配置。

②初始化你的数据库数据

当你调用EF的Database类静态SetInitializer方法时,可以选择以下两个方案中的一种,其一是DropCreateDatabaseAlways,其二是DropCreateDatabaseIfModelChanges

4.初始化你的数据库数据(Seeding to database)

你可以继承自DropCreateDatabaseAlways类并且重写Seed方法

protected override void Seed(MusicStoreDB context)
        {
            context.Artists.Add(new Artist { Name = "罗志祥" });
            
            context.Genres.Add(new Genre { Name="摇滚"});

            context.Albums.Add(new Album
            {
                Arist = new Artist { Name = "周杰伦" },
                Genre = new Genre { Name="中国风"},
                Price = 25.5m,
                Title = "依然范特西"
            });

            base.Seed(context);
        }

然后再Global.asax文件中的Application_Start()方法中添加

Database.SetInitializer(new MusicStoreDbInitializer());

5.完成你的应用程序初始化仅需要三步骤

①完成你的模型类

②利于“基架”构建你的控制器(controller)和视图(Views)

③选择你的数据库初始化策略

  Edit Action

[HttpPost]
public ActionResult Edit(Album album)
{
   if (ModelState.IsValid)
   {
       db.Entry(album).State = EntityState.Modified;
       db.SaveChanges();
       return RedirectToAction("Index");
   }
   ViewBag.GenreId = new SelectList(db.Genres, "GenreId",
                                    "Name", album.GenreId);
   ViewBag.ArtistId = new SelectList(db.Artists, "ArtistId",
                                    "Name", album.ArtistId);
   return View(album);
}

这个方法的职责就是接受用户编辑过后传回来的Album实体;如果实体状态有效,我们把dbContext的状态改为修改模式,最后SaveChanges()就将新的实体对象保存到了数据库中。

  模型绑定

1.你知道编辑视图将要发送一些值为服务器,如果你在服务器端想要接受这些值,你可能会从request中直接获得你想要的值,比如

[HttpPost]
public ActionResult Edit()
{
   var album = new Album();
   album.Title = Request.Form["Title"];
   album.Price = Decimal.Parse(Request.Form["Price"]);
}

这样当有一两个接受值还好,假如有四五个或者更多时,这样的操作就有点麻烦了;

2.MVC提供的模型绑定功能,如果你input输入的name名与属性名相匹配时;MVC运行时会为你的带参action方法提供默认模型绑定功能,它能够自动将回传回来的值转化为album正确的属性类型。换句话来说,模型绑定当发现Album有一个Title的属性,它就会在请求值中寻找名为Name为"Title”的值

3.确认你的模型绑定

当你的方法有参数时,模型绑定就能够确认如何工作了;你仍然需要去确认模型绑定时在你的controller中使用的是UpdateModel还是TryUpdateModel模式,它们之间的区别是:当模型绑定出错或是模型无效时,UpdateModel会抛出异常,而TryUateModel;就像intParse和intTryParse类型;

posted @ 2013-08-04 16:57  霹雳烈火  阅读(670)  评论(0编辑  收藏  举报