本文转自:http://www.cnblogs.com/tomin/archive/2012/02/29/MVC_EntityFramework.html

最近,用到了ASP.NET  MVC Entity Framework  开发了一些项目,感觉还是非常好用了,这让我见证了微软技术的发展:

-通过这个图,我们很清晰的看到,数据访问方式的改变。

如果,你想了解,ADO.NET Entity Framework, 你可以直接访问这个网站  Entity Framework

如果,你想了解ASP.NET MVC , 你可以直接访问这个网站:MVC

下面我介绍一下Entity Framework 的一些运用:

在园子里,我看到很多关于MVC的讲解,很多的用到的是Model First, or Schema First . 在这里,我将结合ASP.NET MVC 3.0 , 做一个Entity Framework CODE FIRST的演示,希望大家能有所帮助。特别是,对你想架构小型项目的时候,这个运用是非常有帮助的.

实验环境:

OS: Windows Server 2008R2, Windows 7

DE: VS2010 + MVC 3.0+Entity Framework+ SQL Server 2008 R2

一、创建MVC 3.0的网站项目,这和大家创建其他的MVC项目是一样的。注意:在创建之前,记得先安装MVC 3.0, Entity Framework. 创建完之后,你将会看到经典的MVC 模式,Model->View->Control

二、在Model中添加2个类,一个是Restaurant,一个是OdeToFoodDB, 定义如下:

Restaurant

using System; using System.Collections.Generic; using System.Linq; using System.Web;
namespace MVCET.Models {     public class Restaurant     {         public int ID { get; set; }         public string  Name { get; set; }         public string State { get; set; }         public Adress  Adress { get; set; }                } }
OdeToFoodDB

using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Data.Entity;
namespace MVCET.Models {     public class OdeToFoodDB:DbContext     {                 public DbSet<Restaurant> Restaurants { get; set; }         public DbSet<Reviewers> Reviewer { get; set; }     } }

OdeToFoodDB, 注意这个类必须继承 DbContext

然后,在webConfig中添加一个数据库连接字符串,如下:

<configuration>   <connectionStrings>     <add name="ApplicationServices"          connectionString="data source=.\SQLEXPRESS;Integrated Security=SSPI;AttachDBFilename=|DataDirectory|aspnetdb.mdf;User Instance=true"          providerName="System.Data.SqlClient" />     <add name="OdeToFoodDB"          connectionString="data source=.\SQLEXPRESS;Integrated Security=SSPI;initial catalog=OdeToFoodDB;"     providerName="System.Data.SqlClient"/>
  </connectionStrings>

三、在Control 中添加RestaurantControl 类,再为Index()函数添加View. 并且选择强类型去显示数据。这时候,view 会自动绑上数据,显示数据。这时候,肯定没有数据,如果要有数据怎么弄呢?这时候就到根据代码生成数据库。 四、在VS 中选择服务器浏览器窗口,在数据库的节点上选择"Add Connection …." 中文版的就是“添加新的连接”。写上数据库的服务器名称,在填上数据库的名字,如下图所示:

点击ok,然后创建数据库,如果,有对话框弹出来,选择"Yes" 就行了。这时候,系统就会自动生成数据库了,如下图所示

我们,看到Restaurants 表中的字段和我们定义的Restaurant中字段的名字基本类似的   到现在为止,我们已经根据代码结构生成了数据库.但是,如果Restaurant 中的字段有所改变,怎办办呢?这时候,就要到Drop以前的数据库,然后,重现建立数据库  五、类发生了改变,数据库也发生对应的改变: 在Global.asax 中的 Application_Start() 函数中,添加以下的代码

 
protected void Application_Start()         {            // Database.SetInitializer(new DropCreateDatabaseIfModelChanges<OdeToFoodDB>());              Database.SetInitializer(new OdeToFoodDBInitializer());              AreaRegistration.RegisterAllAreas();
            RegisterGlobalFilters(GlobalFilters.Filters);             RegisterRoutes(RouteTable.Routes);         }
 

你也可以写一个类继承DropCreateDatabaseIfModelChanges<OdeToFoodDB>, 如下代码所示,你就可以不用注释的哪一行代码了

OdeToFoodDBInitializer

public class OdeToFoodDBInitializer :         DropCreateDatabaseIfModelChanges<OdeToFoodDB>     {         protected override void Seed(OdeToFoodDB context)         {             base.Seed(context);
            context.Restaurants.Add(                 new Restaurant()                 {                     Name = "qitian",                     Adress = new Adress() { Street = " Nanjiang RD, MD", City = "Shanghai" }                 });
            context.Restaurants.Add(                 new Restaurant()                 {                     Name = "haiyun",                     Adress = new Adress() { Street = " Dongchuan RD, MD", City = "Shanghai" }                 });             context.Restaurants.Add(                 new Restaurant()                 {                     Name = "qitian",                     Adress = new Adress() { Street = " Beijing RD, HF", City = "Guangdong" }                 });
            context.Restaurants.Add(                 new Restaurant()                 {                     Name = "Lantian",                     Adress = new Adress() { Street = " Wuhan RD, HF", City = "Guangdong" }                 });
            context.Reviewer.Add(new Reviewers() {              Name="Tomin", Sex="Female"});             context.Reviewer.Add(new Reviewers()             {                                Name = "Tony",                 Sex = "Male"             });
            context.SaveChanges();                          }     }

重新运行运用程序,会给你一个意想不到的结果,你会惊呆的。

MVCET.zip

[转]ASP .NET MVC 之Entity Framework- code first的更多相关文章

  1. ASP.NET MVC with Entity Framework and CSS一书翻译系列文章之第一章:创建基本的MVC Web站点

    在这一章中,我们将学习如何使用基架快速搭建和运行一个简单的Microsoft ASP.NET MVC Web站点.在我们马上投入学习和编码之前,我们首先了解一些有关ASP.NET MVC和Entity ...

  2. ASP.NET MVC with Entity Framework and CSS一书翻译系列文章之目录导航

    ASP.NET MVC with Entity Framework and CSS是2016年出版的一本比较新的.关于ASP.NET MVC.EF以及CSS技术的图书,我将尝试着翻译本书以供日后查阅. ...

  3. 使用MiniProfiler给Asp.net MVC和Entity Framework号脉(附源码)

    在学习python开发框架pylons/pyramid的过程中,里面有个非常棒的页面性能监控功能,这样在开发过程中,你能清楚的知道当前页面的性能以及其它参数. 这里介绍一下如何给Asp.net MVC ...

  4. Using the Repository Pattern with ASP.NET MVC and Entity Framework

    原文:http://www.codeguru.com/csharp/.net/net_asp/mvc/using-the-repository-pattern-with-asp.net-mvc-and ...

  5. [转]Using the Repository Pattern with ASP.NET MVC and Entity Framework

    本文转自:http://www.codeguru.com/csharp/.net/net_asp/mvc/using-the-repository-pattern-with-asp.net-mvc-a ...

  6. ASP.NET MVC+EasyUI+Entity FrameWork 整合开发

    本文详细讲解怎么用ASP.NET MVC+EasyUI+Entity FrameWork 来开发一个项目 对于ASP.NET MVC的Jscript库,主要引用 <script type=.mi ...

  7. ASP.NET MVC with Entity Framework and CSS一书翻译系列文章之第六章:管理产品图片——多对多关系(上篇)

    在这章中,我们将学习如何创建一个管理图片的新实体,如何使用HTML表单上传图片文件,并使用多对多关系将它们和产品关联起来,如何将图片存储在文件系统中.在这章中,我们还会学习更加复杂的异常处理,如何向模 ...

  8. MVC使用Entity Framework Code First,用漂亮表格显示1对多关系

    部门和职员是1对多关系.用一个表格列出所有部门,并且在每行显示该部门下的所有职员名称.如下: 部门和职员的Model: using System.Collections.Generic; namesp ...

  9. ASP.NET MVC with Entity Framework and CSS一书翻译系列文章之第二章:利用模型类创建视图、控制器和数据库

    在这一章中,我们将直接进入项目,并且为产品和分类添加一些基本的模型类.我们将在Entity Framework的代码优先模式下,利用这些模型类创建一个数据库.我们还将学习如何在代码中创建数据库上下文类 ...

  10. ASP.NET MVC with Entity Framework and CSS一书翻译系列文章之第四章:更高级的数据管理

    在这一章我们将学习如何正确地删除分类信息,如何向数据库填充种子数据,如何使用Code First Migrations基于代码更改来更新数据库,然后学习如何执行带有自定义错误消息的验证. 注意:如果你 ...

随机推荐

  1. oracle删除表前先判断表是否存在

     DECLARE  numbe NUMBER;BEGIN  SELECT COUNT(1)    INTO numbe    FROM USER_TABLES   WHERE TABLE_NAME = ...

  2. MongoDB小结12 - update【多文档更新】

    当一次更新一个文档无法满足我们的脚步时,我们可以选择一次更新多个文档,及在update的第四个参数的位置添上true,及做多文档更新,建议就算不做多文档更新也显式的在第四个参数上置false,这样明确 ...

  3. 手把手教你开发Chrome扩展三:关于本地存储数据

    手把手教你开发chrome扩展一:开发Chrome Extenstion其实很简单 手把手教你开发Chrome扩展二:为html添加行为 手把手教你开发Chrome扩展三:关于本地存储数据 HTML5 ...

  4. SaltStack学习笔记之安装zabbix_agentd(jinja和pillar)

    一.环境说明 机器 IP 主机名 Master 192.168.0.23 minion.saltstack.com Minion 192.168.0.35 minion-node2.saltstack ...

  5. php把时间计算成几分钟前,几小时前,几天前的函数

    function time_tran($the_time){ $now_time = date("Y-m-d H:i:s",time()+8*60*60); $now_time = ...

  6. android几个高速打包命令

    在MTK  android4.4 上,有几条命令能够高速打包system uaserdata bootimage,可提高效率. snod:这个命令是能够高速打包system.是不会运行android各 ...

  7. HDMI接口基础知识及硬件设计

    参考资料:http://blog.csdn.net/u013625961/article/details/53434189: http://blog.csdn.net/u014276460/artic ...

  8. Android官方api的下载

    不少开发者,都需要api来进行参考,可是目前Android开发来说默认是没有下载的, 而且sdk中有时候部分开发者也很疑惑怎么没有找到像document或者doc之类的文档进行下载,其实我们只要在把s ...

  9. [软件分享]aboboo英语复读机 使用心得

    软件名称:aboboo www.aboboo.com 作用:英语复读,社区互动,丰富的材料,可以全方位锻炼听说能力. 技巧1:如何锻炼口语? 注册一个帐号,登陆后下载使用社区自带的课件,然后使用“随意 ...

  10. OSS与文件系统的对比

    基本概念介绍_开发指南_对象存储 OSS-阿里云  https://help.aliyun.com/document_detail/31827.html 强一致性 Object 操作在 OSS 上具有 ...