1. 新建项目
打开VS2010,选择 文件>新建>项目,新建ASP.NET MVC3 Web 应用程序,我这里把它命名为Blog。
2. 编写实体类
对于一个博客,一下几个类应该是必须的吧:
- Post???????????????????????????? 博客文章类
- Comment???????????????????? 文章评论类,和Post是一对多的关系
- Category???????????????????? 目录类,和Post是一对多的关系
- Tag???????????????????????????? 标签类,和Post是多对多的关系
- FriendLink????????????????? 友情链接类
先不考虑管理员之类的东西。 在Model中依次添加上面的类。
05 |
???????? public int ID { get ; set ; }
|
06 |
???????? public int CategoryID { get ; set ; }
|
08 |
???????? public string Title { get ; set ; }
|
09 |
???????? public string Summary { get ; set ; }
|
10 |
???????? public string Alias { get ; set ; }
|
11 |
???????? public string Content { get ; set ; }
|
12 |
???????? public DateTime CreateTime { get ; set ; }
|
14 |
???????? public Category Category { get ; set ; }
|
15 |
???????? public ICollection<Tag> Tags { get ; set ; }
|
16 |
???????? public ICollection<Comment> Coments { get ; set ; }
|
03 |
???? public class Comment
|
05 |
???????? public int ID { get ; set ; }
|
06 |
???????? public int PostID { get ; set ; }
|
07 |
???????? public int Level { get ; set ; }
|
08 |
???????? public int ReplyTo { get ; set ; }
|
10 |
???????? public string UserName { get ; set ; }
|
11 |
???????? public string Email { get ; set ; }
|
12 |
???????? public string Website { get ; set ; }
|
13 |
???????? public string Content { get ; set ; }
|
14 |
???????? public DateTime CreateTime { get ; set ; }
|
03 |
???? public class Category
|
05 |
???????? public int ID { get ; set ; }
|
07 |
???????? public string Name { get ; set ; }
|
08 |
???????? public string Alias { get ; set ; }
|
09 |
???????? public string Description { get ; set ; }
|
10 |
???????? public DateTime CreateTime { get ; set ; }
|
12 |
???????? public ICollection<Post> Posts { get ; set ; }
|
05 |
???????? public int ID { get ; set ; }
|
07 |
???????? public string Name { get ; set ; }
|
08 |
???????? public string Alias { get ; set ; }
|
09 |
???????? public DateTime CreateTime { get ; set ; }
|
11 |
???????? public ICollection<Post> Posts { get ; set ; }
|
03 |
???? public class FriendLink
|
05 |
???????? public int ID { get ; set ; }
|
07 |
???????? public string Name { get ; set ; }
|
08 |
???????? public string URL { get ; set ; }
|
09 |
???????? public string Description { get ; set ; }
|
10 |
???????? public DateTime CreateTime { get ; set ; }
|
3. 添加EFCodeFirst
选择菜单栏的 工具 > Library Package Magager > Package Manager Console
在Package Manager Console中输入以下命令安装EFCodeFirst
1 |
PM> install -package efcodefirst
|
安装成功后,VS会自动在你的项目中添加对EntityFramework的引用。
4. 配置
EFCodeFirst的配置是相当的简单,我们向Model中添加BlogDB类。
01 |
using System.Data.Entity;
|
05 |
???? public class BlogDB : DbContext
|
07 |
???????? public DbSet<Post> Posts { get ; set ; }
|
08 |
???????? public DbSet<Tag> Tags { get ; set ; }
|
09 |
???????? public DbSet<Category> Categories { get ; set ; }
|
10 |
???????? public DbSet<Comment> Comments { get ; set ; }
|
11 |
???????? public DbSet<FriendLink> FriendLinks { get ; set ; }
|
打开web.config文件,添加链接字符串
03 |
???????? connectionString="Server=.\;
|
04 |
?????????? Database = Blog ; Trusted_Connection = true "?
|
05 |
???????? providerName = "System.Data.SqlClient" />
|
注意,name属性的值为“BlogDB”这里和BlogDB这个类的类名保持一致。数据库名称为Blog(这个数据库现在并不存在)。
5. 小试牛刀
新建一个HomeController,添加如下代码。
03 |
namespace Blog.Controllers
|
05 |
???? public class HomeController : Controller
|
07 |
???????? BlogDB _db = new BlogDB();
|
11 |
???????? public ActionResult Index()
|
13 |
???????????? var posts = _db.Posts;
|
14 |
???????????? return View(posts);
|
给Index Action创建一个View,如下图示:
添加完后就迫不及待的果断的奋力的按下F5吧,让我们看看都发生了什么!
网页显示了如下信息,不过这不是今天的重点,今天的重点是数据库。让我们打开数据库看看,里面发生了什么。
看吧,EF自动的为我们创建了数据库。
而且,EF足够聪明的为我们完成了Posts到Tags的多对多联系!!!我们程序中并没有和TagPosts表对应的Model,有的只是如下的两行代码
在Post类中
1 |
public ICollection<Tag> Tags { get ; set ; }
|
在Tag类中
1 |
public ICollection<Post> Posts { get ; set ; }
|
我们可以简单的使用如下的代码来获得标签“CSharp”中的所有文章。
2 |
??????????????? .Where(t => t.Name == "CSharp" )
|
3 |
??????????????? .Single()
|
6. 修改Model后,自动更新数据表
当我们修改了Model后,运行网站时,会报错,因为EF现在不能把更新后的Model和旧数据表对应起来。为了使数据库随着Model的更新而更新,我们还要做以下的工作。
打开根目录下的Global.asax文件
添加如下命名空间(注意:EFCodeFirst 1.0 和 0.8 对于 DataBase 类所在的命名空间不同)
1 |
using System.Data.Entity;
|
新建一个BlogDBInitializer类,使他继承DropCreateDatabaseIfModelChanges<BlogDB>,重写Seed函数。
01 |
public class BlogDBInitializer?
|
02 |
???? : DropCreateDatabaseIfModelChanges<BlogDB>
|
04 |
???? protected override void Seed(BlogDB context)
|
06 |
???????? base .Seed(context);
|
08 |
???????? var links = new List<FriendLink>
|
10 |
???????????? new FriendLink{
|
11 |
???????????????? Name= "NinoFocus.com" ,
|
12 |
???????????????? URL= @"http://ninofocus.com" ,
|
13 |
???????????????? Description= "NinoFocus的个人博客"
|
15 |
???????????? new FriendLink{
|
16 |
???????????????? Name= "NinoFocus at CNBlogs" ,
|
17 |
???????????????? URL= @"http://www.cnblogs.com/nizhuguo" ,
|
18 |
???????????????? Description= "NinoFocus在博客园的博客"
|
21 |
???????? links.ForEach(l => context.FriendLinks.Add(l));
|
22 |
???????? context.SaveChanges();
|
向Application_Start()中,添加如下代码
每次重建数据库后,数据库中的数据都是被清空。而Seed()函数的作用就是向新的数据库中添加以下初始化数据。
如上面的代码我添加了两个友情链接。