在ASP.NET MVC3中使用EFCodeFirst 1.0

作者: NinoFocus  來源: 博客園  發布時間: 2011-04-12 10:41  閱讀: 14820 次  推薦: 12   原文鏈接   [收藏]  

  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 { 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。

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框架,可能還有很多地方我沒注意到,或者說錯了,請大家多多指教!

12
1
 
 
 

文章列表

arrow
arrow
    全站熱搜
    創作者介紹
    創作者 大師兄 的頭像
    大師兄

    IT工程師數位筆記本

    大師兄 發表在 痞客邦 留言(0) 人氣()