在ASP.NET MVC3中使用“.NET研究”EFCodeFirst 1.0

简介:   1. 新建项目  打开VS2010,选择 文件>新建>项目,新建ASP.NET MVC3 Web 应用程序,我这里把它命名为Blog。   2. 编写实体类  对于一个博客,一下几个类应该是必须的吧:Post                             博客文章类 Co...

  1. 新建项目

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

image

  2. 编写实体类

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

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

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

image

 
 
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。

image

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

PM> install-package efcodefirst 。

image  安装成功后,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,如下图示:

image

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

image

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

image

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

image

  而且,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()中,添加如下代码:

image

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

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

  7. 写在最后

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

目录
相关文章
|
3月前
|
开发框架 前端开发 .NET
VB.NET中如何利用ASP.NET进行Web开发
在VB.NET中利用ASP.NET进行Web开发是一个常见的做法,特别是在需要构建动态、交互式Web应用程序时。ASP.NET是一个由微软开发的开源Web应用程序框架,它允许开发者使用多种编程语言(包括VB.NET)来创建Web应用程序。
71 5
|
4月前
|
开发框架 JSON .NET
ASP.NET Core 标识(Identity)框架系列(三):在 ASP.NET Core Web API 项目中使用标识(Identity)框架进行身份验证
ASP.NET Core 标识(Identity)框架系列(三):在 ASP.NET Core Web API 项目中使用标识(Identity)框架进行身份验证
|
4月前
|
开发框架 .NET 开发工具
【Azure 应用服务】App Service 的.NET Version选择为.NET6,是否可以同时支持运行ASP.NET V4.8的应用呢?
【Azure 应用服务】App Service 的.NET Version选择为.NET6,是否可以同时支持运行ASP.NET V4.8的应用呢?
|
5月前
|
开发框架 搜索推荐 前端开发
【.NET全栈】ASP.NET开发Web应用——Web部件技术
【.NET全栈】ASP.NET开发Web应用——Web部件技术
|
4月前
|
开发框架 .NET 数据库连接
ASP.NET Core 标识(Identity)框架系列(一):如何使用 ASP.NET Core 标识(Identity)框架创建用户和角色?
ASP.NET Core 标识(Identity)框架系列(一):如何使用 ASP.NET Core 标识(Identity)框架创建用户和角色?
|
6月前
|
Linux C# C++
【.NET Developer】创建ASP.NET Core Blazor项目并打包为Linux镜像发布到Azure应用服务
本文介绍了如何使用VS2019和.NET框架创建一个Blazor应用,并将其部署到Azure应用服务。首先,Blazor是一个使用C#而非JavaScript构建交互式Web UI的框架,支持共享服务器和客户端应用逻辑,以及与Docker和Azure集成。任务包括创建Blazor项目,配置Dockerfile为Linux容器,本地测试,发布到Azure Container Registry (ACR),然后在Azure App Service for Container上部署。在部署过程中,需确保Docker设置正确,开启ACR的Admin访问权限,并监控镜像拉取和容器启动日志。
286 0
|
4月前
|
开发框架 前端开发 .NET
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
60 0
|
7月前
|
开发框架 前端开发 .NET
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
214 0
|
7月前
|
开发框架 前端开发 JavaScript
JavaScript云LIS系统源码ASP.NET CORE 3.1 MVC + SQLserver + Redis医院实验室信息系统源码 医院云LIS系统源码
实验室信息系统(Laboratory Information System,缩写LIS)是一类用来处理实验室过程信息的软件,云LIS系统围绕临床,云LIS系统将与云HIS系统建立起高度的业务整合,以体现“以病人为中心”的设计理念,优化就诊流程,方便患者就医。
87 0
|
存储 开发框架 前端开发
[回馈]ASP.NET Core MVC开发实战之商城系统(五)
经过一段时间的准备,新的一期【ASP.NET Core MVC开发实战之商城系统】已经开始,在之前的文章中,讲解了商城系统的整体功能设计,页面布局设计,环境搭建,系统配置,及首页【商品类型,banner条,友情链接,降价促销,新品爆款】,商品列表页面,商品详情等功能的开发,今天继续讲解购物车功能开发,仅供学习分享使用,如有不足之处,还请指正。
176 0