在ASP.NET MVC3中使用“.NET研究”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 { g上海闵行企业网站制作et; 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; 上海网站建设/span>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-10-10 16:10:52

在ASP.NET MVC3中使用“.NET研究”EFCodeFirst 1.0的相关文章

ASP.NET MVC3中Model验证

原文:ASP.NET MVC3中Model验证  概述 上节我们学习了Model的数据在界面之间的传递,但是很多时候,我们在数据传递的时候为了确保数据的有效性,不得不给Model的相关属性做基本的数据验证. 本节我们就学习如何使用 System.ComponentModel.DataAnnotations 命名空间中的特性指定对数据模型中的各个字段的验证. 这些特性用于定义常见的验证模式,例如范围检查和必填字段.而 DataAnnotations 特性使 MVC 能够提供客户端和服务器验证检查,

ASP.NET MVC3 中的UrlRewrite用法介绍

ASP.NET MVC3中自带的Url重写工具,今天和大家一起分享一下简单的实现过程. 最后要实现的结果:以二级域名的形式传递城市拼音并解析.如下图所示: 第一步:创建一个UrlProvider.cs类文件,其类要继承路由基类RouteBase.  代码如下 复制代码 继承RouteBase后需要实现两个方法: public override RouteData GetRouteData(HttpContextBase httpContext) {     throw new NotImplem

一起谈.NET技术,在ASP.NET MVC3 中利用JSONP跨域登录WEB系统

在信息系统开发的时,根据相关业务逻辑难免会多系统之间互相登录.一般情况下我们需要在多系统之间使用多个用户名和密码.这样客户就需要在多个系统之间重复登陆.每次登录都需要输入用户名和密码.最近比较流行的就是OAuth.新浪微博这个开放系统做的就很好.但OAuth并非本文讨论范畴.这里主要讨论jQuery1.5 jsonp 在Asp.net MVC3 中的应用. 本文应用场景: 假设您的开发团队欲为某集团公司开发一整套信息管理系统,目前首要开发的就是一套订单系统和一套内部OA系统.前提是这两套系统使用

在ASP.NET MVC3 中利用JSONP跨域登“.NET技术”录WEB系统

在信息系统开发的时,根据相关业务逻辑难免会多系统之间互相登录.一般情况下我们需要在多系统之间使用多个用户名和密码.这样客户就需要在多个系统之间重复登陆.每次登录都需要输入用户名和密码.最近比较流行的就是OAuth.新浪微博这个开放系统做的就很好.但OAuth并非本文讨论范畴.这里主要讨论jQuery1.5 jsonp 在Asp.net MVC3 中的应用. 本文应用场景: 假设您的开发团队欲为某集团公司开发一整套信息管理系统,目前首要开发的就是一套订单系统和一套内部OA系统.前提是这两套系统使用

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

1. 新建项目 打开VS2010,选择 文件>新建>项目,新建ASP.NET MVC3 Web 应用程序,我这里把它命名为Blog. 2. 编写实体类 对于一个博客,一下几个类应该是必须的吧: Post                             博客文章类 Comment                     文章评论类,和Post是一对多的关系 Category                     目录类,和Post是一对多的关系 Tag                 

浅谈ASP.NET 4中构造“.NET研究”HTML5视频控件

在本文中,将一步步地指导你如何使用Visual Studio 2010和ASP.NET 4的相关知识,打造一个基于HTML5标准规范的视频播放控件,其中你会学习到一些关于HTML 5的知识,还会学到如何使用ASP.NET 4去打造一个服务端的控件. 简介 ASP.NET 4中有大量由微软或第三方提供的控件,但要是这些控件不能满足你的需求,那该怎么办呢?答案是:自己动手去设计! 本教程会指导你如何去开发一个ASP.NET 的服务端控件,你会感受到在开发自己的服务端控件的同时,也提升了你开发的Web

asp net mvc-asp.net mvc3中的小问题。

问题描述 asp.net mvc3中的小问题. asp.net mvc3 中,在view中用jquery的$.post添加数据成功后,用$.get加载所有数据,为什么显示不了$.post的数据呢? 这是页面的js: $("#dialog-form").dialog({ autoOpen: false, height: 400, width: 400, mode: true, buttons: { 'ok': function () { var name = $("#Name&

Asp.Net MVC3 简单入门第一季(一)环境准备

前言 大家好,从今天开始我将写一个关于AspNet MVC3方面学习的总结,并跟初学者一起分享一些基本的基础知识,作者本身也很愿意跟大家一起交流技术,一起交流一起进步,欢迎高手不吝赐教,欢迎大家不同的意见和建议,作者的学识和见识当然有自己的局限性,希望自己能成为不闷骚型的技术人员,而不是只自己享受技术,而不让更多的人来分享你的成果的人. 第一节:关于Asp.Net MVC3 Asp.Net MVC已经到第三版了,相信大家也都熟悉了,我也不再重复相关概念性的东西了.但是大家一定要了解,Asp.Ne

Html.Action和Html.RenderAction:ASP.NET MVC中的HTML辅助方法

Html.Action和Html.RenderAction Action是执行单独的控制器操作并显示结果,Action提供了更多的灵活性和重用性,因为控制器操作可以建立不用的模型,可以利用单独的控制器上下文,他们两个仅有的不同是:RenderAction可以直接写入响应流.下面看一下代码: public class MyController { public ActionResult Index() { return View(); } [ChildActionOnly] public Acti