1.建立MVC项目》NuGet安装EF

2.建立模型:

public class Blog
{
[Key]
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public Guid Id { get; set; }
public string Title { get; set; }
public string Author { get; set; }
public DateTime Time { get; set; }
public string Summary { get; set; }
public string Content { get; set; }
public virtual ICollection<Comment> Comments { get; set; } = new List<Comment>();
} public class Comment
{
[Key]
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public Guid Id { get; set; }
public string VisitorName { get; set; }
public string Email { get; set; }
public DateTime Time { get; set; }
public string Content { get; set; } [ForeignKey("Blog")]
public Guid BlogId { get; set; }
public virtual Blog Blog { get; set; }
}

模型需要引用命名空间:

using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;

3.建立数据库类 DbContext:

public class EFDbContext : DbContext
{
public DbSet<Product> Products { get; set; }
public DbSet<Blog> Blogs { get; set; }
public DbSet<Comment> Comments { get; set; }
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
modelBuilder.Conventions.Remove<PluralizingTableNameConvention>(); //去除“设置表名为复数”这条约定
}
}

DbContext需要引用命名空间:

using System.Data.Entity;
using System.Data.Entity.ModelConfiguration.Conventions;

4.配置web.config数据库连接,连接名称需要是EFDbContext,和建立的DbContext名称一致;或者在EFDbContext中使用构造函数指定连接名称:

public EFDbContext() : base("数据库链接的结点名字") { }

<add name="EFDbContext" connectionString="Data Source=.;Initial Catalog=db_codefirst_test;Persist Security Info=True;User ID=sa;Password=123456;" providerName="System.Data.SqlClient" />

记得加上:providerName="System.Data.SqlClient"

5.新建一个测试Controller,选择具有增删改查的模板,然后选择对应的模型类、数据库上下文类。

6.运行程序,浏览刚才建的Controller的View,数据库就自动建好了。

7.要是修改模型类,数据库中的表需要删了重建。

8.可自动根据模型变化重新建库,并插入初始化数据,选择不同模式即可。

DropCreateDatabaseIfModelChanges:当模型改变时,重新建库;

DropCreateDatabaseAlways:每次启动程序时,重新建库;

Seed方法用来插入数据。

/// <summary>
/// 数据库初始化
/// </summary>
public class BaseInitializer : DropCreateDatabaseIfModelChanges<EFDbContext>
{
//CreateDatabaseIfNotExists:数据库不存在时重新创建数据库
//DropCreateDatabaseIfModelChanges:当模型改变时,重新建库;
//DropCreateDatabaseAlways:每次启动程序时,重新建库;
protected override void Seed(EFDbContext context)
{
var blogs = new List<Models.Blog>
{
new Models.Blog{ Author="小明", Content="老师:小明,你给我滚出去!", Time=DateTime.Now, Title="小明日常", Comments=new List<Models.Comment>(){
new Comment(){ Content = "test", Email="908085411@qq.com", Time=DateTime.Now, VisitorName="jay.x" }
} },
new Models.Blog{ Author="小红", Content="老师:小红,你去看看小明去哪儿了!", Time=DateTime.Now, Title="小红日常"},
new Models.Blog{ Author="小蓝", Content="小蓝:老师,小明和小红在玩游戏!", Time=DateTime.Now, Title="小蓝日常"},
new Models.Blog{ Author="小白", Content="小白:我去看看!", Time=DateTime.Now, Title="小白日常"},
new Models.Blog{ Author="小黄", Content="小黄:我也去看看!", Time=DateTime.Now, Title="小黄日常"}
}; blogs.ForEach(s => context.Blogs.Add(s));
context.SaveChanges(); var cou = new List<Models.Product>
{
new Models.Product{ Name="西瓜", Price=decimal.Parse("3.5")},
new Models.Product{ Name="油桃", Price=decimal.Parse("")},
}; cou.ForEach(c => context.Products.Add(c));
context.SaveChanges();
}
}

BaseInitializer

在Global中注册这个初始化类:

protected void Application_Start()
{
......... //添加建表
Database.SetInitializer<EFDbContext>(new BaseInitializer());
}

//添加自动化建表,一般情况第一次运行需要这么写
//当修改了Model,又不想删除重建的时候,把SetInitializer的参数设null。
//原因是:删除重建会把测试数据也清除了
//Database.SetInitializer<EFDbContext>(null);
Database.SetInitializer<EFDbContext>(new BaseInitializer());
误删表,如何恢复:http://www.cnblogs.com/bleychen/p/4350913.html

EF通用数据层封装类:https://www.cnblogs.com/qtqq/p/6942312.html

MVC之CodeFirst的更多相关文章

  1. C# 动态生成word文档 [C#学习笔记3]关于Main(string[ ] args)中args命令行参数 实现DataTables搜索框查询结果高亮显示 二维码神器QRCoder Asp.net MVC 中 CodeFirst 开发模式实例

    C# 动态生成word文档 本文以一个简单的小例子,简述利用C#语言开发word表格相关的知识,仅供学习分享使用,如有不足之处,还请指正. 在工程中引用word的动态库 在项目中,点击项目名称右键-- ...

  2. 新年奉献MVC+EF(CodeFirst)+Easyui医药MIS系统

    本人闲来无事就把以前用Asp.net做过的一个医药管理信息系统用mvc,ef ,easyui重新做了一下,业务逻辑简化了许多,旨在加深对mvc,ef(codefirst),easyui,AutoMap ...

  3. Asp.net MVC 中 CodeFirst 开发模式实例

    昨天写的这篇博客因为下班时间到了忘记保存了,好郁闷,得重新写一遍.实习所在公司使用的是CodeFirst开发模式,最近开始参与到公司的项目里面来了,发现这个模式特别好用,建库建表改变字段属性添加删除字 ...

  4. Asp.Net MVC +EF CodeFirst+多层程序设计

    1.概述 这是一个基于个人博客的一个项目,虽然博客根本没必要做这么复杂的设计.但是公司有需求,所以先自己弄个项目练练手.项目需要满足下列需求 1.层与层之间需要解耦,在后期上线更新维护时不需要覆盖,只 ...

  5. 新年奉献MVC+EF(CODEFIRST)+EASYUI医药MIS系统(转)

    出处:http://www.cnblogs.com/chenlinzhi/p/4332628.html 本人闲来无事就把以前用Asp.net做过的一个医药管理信息系统用mvc,ef ,easyui重新 ...

  6. 分享基于.NET MVC+EF CodeFirst+IOC+EasyUI的框架设计

    **注:要做工,没什么时间,等有空时会上传到GIT,项目结构如上,简单的说一下: **支持IOC及多数据库等,各项目由MVC区域隔离: 主要使用基于接口与抽象类进行高度的抽象与接口隔离,与其它框架比较 ...

  7. 七:mvc使用CodeFirst(代码优先)创建数据库

    1. 理解EF CodeFirst模式特点 2. 使用CodeFirst模式生成数据库 1. CodeFirst模式(代码优先) Code First是Entity Framework提供的一种新的编 ...

  8. (七)学习MVC之CodeFirst迁移更新数据库

    1.首先在程序包管理控制台输入:enable-migrations -force ,然后回车: 问题1: The EntityFramework package is not installed on ...

  9. MVC+EF(CODEFIRST)+EASYUI医药MIS系统

    https://www.cnblogs.com/chenlinzhi/p/4332628.html

随机推荐

  1. ASP.NET HTTP 协议

    http是无状态的,不会记得“上个请求***”,所以哪怕是同一个页面中的js.css.jpg也都要重复的提交Accept-Language.Accept-Encoding.Cookie等. 一般情况下 ...

  2. KVM虚拟化技术(六)磁盘管理

    KVM支持的虚拟磁盘类型 raw 这并非是一种真正的磁盘格式,而是代表虚拟机所使用的原始镜像:它并不存储元数据,因此可以作为保证虚拟机兼容性的候选方案,然而也正因为 它不存储元数据,因此不能支持某些高 ...

  3. 25.week4 docker build 也就是创建自己的image 上传image到dockerhub 从dockerhub下载images

    dado可以写你自己的名字 这个命令就会根据目录下的Dockerfile(固定用和这个名字)文件里面的内容 去下载并创建运行命令一步一步地 Setting up libxfixes3:amd64 (: ...

  4. Hibernate 再接触 基础配置 续

    <property name="show_sql">true</property> 这句话是意思显示sql语句 <property name=&quo ...

  5. Oracle 导入大量数据

    环境是这样的: 需要导入大量数据到Oracle,目前Oracle已建立索引和触发器了,导入的数据是树型结构,需要关联. 采用的方法是: 删除以前数据库的索引和触发器,用OracleBulkCopy批量 ...

  6. ERROR Couldn't find hvm kernel for Ubuntu tree.

    安装python-virtinst git clone https://github.com/palli/python-virtinst.gitcd python-virtinstpython set ...

  7. Beanutils.copyProperties( )的使用与优化

    1.使用原因 因为现在都是前后端分离所以我们在响应APP端或者前端的时候会维护一套VO,那么DTO到VO的转换便是一堆get... set...这样的代码,比如好几个地方用到的话还要去复制粘贴来转换. ...

  8. 用R理解统计学

    1.随机变量( random variable)概念的引入 该数据来自杰克逊实验室.2组数据,每组12只老鼠,一组普通食物,另一组高脂肪(hf)饮食.几周后,科学家们称了每只老鼠的体重,得到了这个数据 ...

  9. 解题2(IpIsSameSubNet)

    题目描述 子网掩码是用来判断任意两台计算机的IP地址是否属于同一子网络的根据.子网掩码与IP地址结构相同,是32位二进制数,其中网络号部分全为“1”和主机号部分全为“0”.利用子网掩码可以判断两台主机 ...

  10. AS不能真机调试 (转)

    经常遇到这种问题 现总结一下原因 打开手机的开发人员选项,允许USB调试 AS--->tools--->android-->Enable ADB Interation选项 勾上. A ...