一起谈.NET技术,在ASP.NET MVC3中使用EFCodeFirst 1.0

  1. 新建项目

  打开VS2010,选择 文件>新建>项目,新建ASP.NET MVC3 Web 应用程序,我这里把它命名为Blog。

  2. 编写实体类

  对于一个博客,一下几个类应该是必须的吧:

  • Post                             博客文章类
  • Comment                     文章评论类,和Post是一对多的关系
  • Category                     目录类,和Post是一对多的关系
  • Tag                             标签类,和Post是多对多的关系
  • FriendLink                  友情链接类

  先不考虑管理员之类的东西。 在Model中依次添加上面的类。


namespace Blog.Models
{
public class Post
{
public int ID { get; set; }
public int CategoryID { get; set; }

public string Title { get; set; }
public string Summary { get; set; }
public string Alias { get; set; }
public string Content { get; set; }
public DateTime CreateTime { get; set; }

public Category Category { get; set; }
public ICollection<Tag> Tags { get; set; }
public ICollection<Comment> Coments { get; set; }
}
}

namespace Blog.Models
{
public class Comment
{
public int ID { get; set; }
public int PostID { get; set; }
public int Level { get; set; }
public int ReplyTo { get; set; }

public string UserName { get; set; }
public string Email { get; set; }
public string Website { get; set; }
public string Content { get; set; }
public DateTime CreateTime { get; set; }

}
}

namespace Blog.Models
{
public class Category
{
public int ID { get; set; }

public string Name { get; set; }
public string Alias { get; set; }
public string Description { get; set; }
public DateTime CreateTime { get; set; }

public ICollection<Post> Posts { get; set; }
}
}

namespace Blog.Models
{
public class Tag
{
public int ID { get; set; }

public string Name { get; set; }
public string Alias { get; set; }
public DateTime CreateTime { get; set; }

public ICollection<Post> Posts { get; set; }
}
}

namespace Blog.Models
{
public class FriendLink
{
public int ID { get; set; }

public string Name { get; set; }
public string URL { get; set; }
public string Description { get; set; }
public DateTime CreateTime { get; set; }
}
}

  3. 添加EFCodeFirst

  选择菜单栏的 工具 > Library Package Magager > Package Manager Console。

  在Package Manager Console中输入以下命令安装EFCodeFirst。

PM> install-package efcodefirst 。

  安装成功后,VS会自动在你的项目中添加对EntityFramework的引用。

  4. 配置

  EFCodeFirst的配置是相当的简单,我们向Model中添加BlogDB类。


using System.Data.Entity;

namespace Blog.Models
{
public class BlogDB : DbContext
{
public DbSet<Post> Posts { get; set; }
public DbSet<Tag> Tags { get; set; }
public DbSet<Category> Categories { get; set; }
public DbSet<Comment> Comments { get; set; }
public DbSet<FriendLink> FriendLinks { get; set; }
}
}

  打开web.config文件,添加链接字符串:


<connectionStrings>
<add name="BlogDB"
connectionString="Server=.\;
Database=Blog;Trusted_Connection=true"
providerName="System.Data.SqlClient" />
<!--<add name="BlogDB"
connectionString="Server=.\EXPRESS;
Database=Blog;Trusted_Connection=true"
providerName="System.Data.SqlClient" />-->
</connectionStrings>

  注意,name属性的值为“BlogDB”这里和BlogDB这个类的类名保持一致。数据库名称为Blog(这个数据库现在并不存在)。

  5. 小试牛刀

  新建一个HomeController,添加如下代码。


using Blog.Models;

namespace Blog.Controllers
{
public class HomeController : Controller
{
BlogDB _db = new BlogDB();
//
// GET: /Home/

public ActionResult Index()
{
var posts = _db.Posts;
return View(posts);
}

}
}

  给Index Action创建一个View,如下图示:

  添加完后就迫不及待的果断的奋力的按下F5吧,让我们看看都发生了什么!

  网页显示了如下信息,不过这不是今天的重点,今天的重点是数据库。让我们打开数据库看看,里面发生了什么。

  看吧,EF自动的为我们创建了数据库。

  而且,EF足够聪明的为我们完成了Posts到Tags的多对多联系!!!我们程序中并没有和TagPosts表对应的Model,有的只是如下的两行代码:

  在Post类中:public ICollection<Tag> Tags { get; set; }

  在Tag类中:public ICollection<Post> Posts { get; set; }

  我们可以简单的使用如下的代码来获得标签“CSharp”中的所有文章。


var posts = _db.Tags
.Where(t => t.Name == "CSharp")
.Single()
.Posts;

  6. 修改Model后,自动更新数据表

  当我们修改了Model后,运行网站时,会报错,因为EF现在不能把更新后的Model和旧数据表对应起来。为了使数据库随着Model的更新而更新,我们还要做以下的工作。

  打开根目录下的Global.asax文件。

  添加如下命名空间(注意:EFCodeFirst 1.0 和 0.8 对于 DataBase 类所在的命名空间不同)


using System.Data.Entity;
using Blog.Models;

  新建一个BlogDBInitializer类,使他继承DropCreateDatabaseIfModelChanges<BlogDB>,重写Seed函数。


public class BlogDBInitializer
: DropCreateDatabaseIfModelChanges<BlogDB>
{
protected override void Seed(BlogDB context)
{
base.Seed(context);

var links = new List<FriendLink>
{
new FriendLink{
Name="NinoFocus.com",
URL=@"http://ninofocus.com",
Description="NinoFocus的个人博客"
},
new FriendLink{
Name="NinoFocus at CNBlogs",
URL=@"http://www.cnblogs.com/nizhuguo",
Description="NinoFocus在博客园的博客"
}
};
links.ForEach(l => context.FriendLinks.Add(l));
context.SaveChanges();
}
}

  向Application_Start()中,添加如下代码:

  每次重建数据库后,数据库中的数据都是被清空。而Seed()函数的作用就是向新的数据库中添加以下初始化数据。

  如上面的代码我添加了两个友情链接。

  7. 写在最后

  小弟也是刚学EF框架,可能还有很多地方我没注意到,或者说错了,请大家多多指教!

时间: 2024-12-25 00:50:02

一起谈.NET技术,在ASP.NET MVC3中使用EFCodeFirst 1.0的相关文章

一起谈.NET技术,ASP.NET MVC3 Service Location

介绍 ASP.NET MVC3 的一个重要的新特性就是允许注册一个服务点 Service Location,然后在框架中使用的能力.以前版本的 MVC 已经提供了 Service Location 和依赖注入的机会,在 MVC3 中,我们正式提供了这种能力,并且为开发者开放了多种使用的机会. 总体策略 关于 Service Location 的最重要的部分就是它是可选的,这意味着如果你对 Service Location 不感兴趣,那么,你不需要被强制使用,你总是可以在不使用 Service L

一起谈.NET技术,ASP.NET MVC3 on Mono的折腾(一):Windows下的部署

Mono 2.10支持MVC3和Razor的消息着实让我兴奋了好一会儿,因为支持MVC3后,我就有可能做Kooboo CMS3兼容Mono的相关测试工作.可是没一会儿,我就发现,离我的目标还是有一点距离.不晓得是Mono 2.10本身存在的bug,还是我的原因,我总是无法很完美的在Mono运行起MVC3的站点,即使是用默认的MVC3站点模板创建的非常简单的站点也是一样.长期生活在微软Windows/.NET平台的滋润环境中,没有Linux平台的使用经验和基于配置文件的Web部署习惯,让我花了不少

一起谈.NET技术,ASP.NET MVC3 让依赖注入来的更简单(新补充了Ninject示例)

昨天,我写了一篇文章(参见:ASP.NET MVC 依赖注入),这种实现方式我个人一直感觉不太顺,在写出来与大家一起分享的同时, 也是想让大家提提自己的建议, 今天下载了微软发布的最新的 ASP.NET MVC3 Beta 版,同时也仔细阅读了它的 Release Notes, 让我感觉到惊喜的是,MVC3增加了对依赖注入的支持,增加了一 个 IDependencyResolver 接口定义,真的是很不错,比起我原来的实现要顺畅很多, 还是老方法,上微软牛人们的博客逛一圈看看有没有已经写好的代码

一起谈.NET技术,ASP.NET MVC3 Razor视图引擎-基础语法

I:ASP.NET MVC3在Visual Studio 2010中的变化 在VS2010中新建一个MVC3项目可以看出与以往的MVC2发生了很明显的变化. 1.ASP.NET MVC3必要的运行环境为.NET 4.0 (想在3.5用MVC3,没门!). 2.默认MVC3模板项目已集成 3.全新的Razor视图引擎 @{ ViewBag.Title = "Home Page";} <h2>@ViewBag.Message</h2><p> To lea

一起谈.NET技术,ASP.NET MVC中的Json Binding和Validate

电子商务网站支付功能页面往往会有很多信息,对于这些信息的保存,往往是分步完成的,那么使用Ajax最合适不过了,比如其中的收货人信息模块.这些信息的新建和编辑保存都是用Ajax来完成的.那么有几种方式完成这个操作呢,我想到如下几种. 先来看看该功能的截图: 一般情况下这些信息会对应一个实体类,就命名为:ReceiverInfo,简单起见,我定义ReceiverInfo如下: 1.将需要的值拼接成json文本,再Action里面处理 首先您需要将要保存的值拼接成一个json文本,类似: var te

一起谈.NET技术,ASP.NET MVC中对数据进行排序的方法

本系列是讲解如何在asp.net mvc中对数据进行展示.排序.分页等的系列文章.在上周的文章中,一步一步教会了大家如何使用ASP.NET MVC框架去的展示数据.在上周的文章中,我们先用Visual Studio创建了一个新的ASP.NET MVC应用程序,接着连接到了Northwind数据库,并展示了如何使用微软的LINQ-SQL的工具去访问数据库中的数据,接着指导如何去实现视图层去展示产品信息及如何设计控制器. 本文是在上一篇文章的例子基础上,展示了如何去实现数据的双向排序.如果你是已经熟

一起谈.NET技术,ASP.NET MVC中对Model进行分步验证的解决方法

在我之前的文章:ASP.NET MVC2.0结合WF4.0实现用户多步注册流程中将一个用户的注册分成了四步,而这四个步骤都是在完善一个Model的信息,但是又分页面填写信息的,当时我加上ModelState.IsValid这句验证代码的时候,根本没法通过验证,因为在注册的前面三步,注册用户的Model信息都没填写完整,而ModelState.IsValid是对一个实体的所有属性进行判断验证的.当时很纠结,因为刚接触Asp.net MVC,故没有找到解决方案.这篇文章将给出解决的办法.看下面需要验

一起谈.NET技术,ASP.NET MVC中实现多个按钮提交的几种方法

有时候会遇到这种情况:在一个表单上需要多个按钮来完成不同的功能,比如一个简单的审批功能.   如果是用webform那不需要讨论,但asp.net mvc中一个表单只能提交到一个Action处理,相对比较麻烦点. 方法一:使用客户端脚本 比如我们在View中这样写: 代码 <inputtype="submit"value="审核通过"onclick='this.form.action="<%=Url.Action("Action1&q

一起谈.NET技术,ASP.NET MVC2中Controller向View传递数据的三种方式

在Asp.net mvc开发中,Controller需要向View提供Model,然后View将此Model渲染成HTML.这篇文章介绍三种由Controller向View传递数据的方式,实现一个DropDownList的显示. 第一种:ViewData ViewData是一个Dictionary.使用非常简单,看下面代码: public ActionResult ViewDataWay(int id){ Book book =bookRepository.GetBook(id); ViewDa