EF有三种数据库访问方式,这里只介绍Code First。

1、DB First,类似Linq to sql中拖拽一个DB到方案中

2、Model First,没试过,不能自动生成数据库只能生成表

3、Code First,手写实体类,经过配置后,EF会自动创建数据库和表

Code First配置需经过两步

一、手写实体类,实体类的类名对应着数据库的表名

    public class Sys_User
{
[Key]
public int UserId { get; set; }
public string UserName { get; set; }
}

需注意几点:类名不可为数据库的关键字,比如SysUser需改成Sys_User;实体类必须要有Key,EF现在支持组合Key。

二、重写上下文

    public class MyContext : DbContext
{
public MyContext() : base("name=DefaultConnection") { }
public DbSet<Sys_User> Sys_User { get; set; }
}
<configuration>
<connectionStrings>
<add name="DefaultConnection" providerName="System.Data.SqlClient" connectionString="Data Source=.;Initial Catalog=Biz;user id=sa;password=123456;Integrated Security=True;Connect Timeout=15;Encrypt=False;TrustServerCertificate=False;MultipleActiveResultSets=True" />
</connectionStrings>
</configuration>

测试

using System.ComponentModel.DataAnnotations;
using System.Data.Entity; namespace ConsoleApplication1
{
class Program
{
static void Main(string[] args)
{
MyContext dbContext = new MyContext();
//到此尚未创建表,需操作一次数据库才行,只要查看一个表,其他表也会自动生成的
dbContext.Sys_User.FirstOrDefaultAsync();
}
} public class Sys_User
{
[Key]
public int UserId { get; set; }
public string UserName { get; set; }
}
public class MyContext : DbContext
{
public MyContext() : base("name=DefaultConnection") { }
public DbSet<Sys_User> Sys_User { get; set; }
}
}

至此,测试结束,数据库自动创建了Biz数据库和Sys_User表。

数据库初始化的三种行为

EF还自动创建了__MigrationHistory表,此表是首次加载以及每次数据库迁移的时候会触发的

自动创建数据库通常不能满足需求,我们希望Sys_User表创建的同时自动生成一笔管理员账号。

1、CreateDatabaseIfNotExists,默认行为,没有就创建一个。

2、DropCreateDatabaseIfModelChanges,如果模型改变后,自动重新创建一个新的数据库,在开发中非常有用,但也要小心,如果开发进行到一半要改表会丢失数据。

3、DropCreateDatabaseAlways,每次运行都重新生成数据库。

using System.ComponentModel.DataAnnotations;
using System.Data.Common;
using System.Data.Entity; namespace ConsoleApplication1
{
class Program
{
static void Main(string[] args)
{
MyContext dbContext = new MyContext();
//到此尚未创建表,需操作一次数据库才行
dbContext.Sys_User.FirstOrDefaultAsync();
}
} public class Sys_User
{
[Key]
public int UserId { get; set; }
public string UserName { get; set; }
}
public class MyContext : DbContext
{
public MyContext()
: base("name=DefaultConnection")
{
Database.SetInitializer<MyContext>(new MyInitDB());
}
public DbSet<Sys_User> Sys_User { get; set; }
} public class MyInitDB:CreateDatabaseIfNotExists<MyContext> //: DropCreateDatabaseIfModelChanges<MyContext>
{
/// <summary>
/// 用一些数据对数据库进行初始化
/// 当通过Entity Framework的Code First特性第一次创建数据库架构时,会用到这个类。
/// </summary>
/// <param name="context"></param>
protected override void Seed(MyContext context)
{
InitialSetup(context);
base.Seed(context);
} public void InitialSetup(MyContext context)
{
context.Sys_User.Add(new Sys_User { UserName = "admin" });
context.SaveChanges();
}
}
}

迁移

如果开发到一半有表要调整,当我们调整实体类的时候(且选择的是CreateDatabaseIfNotExists模式)时怎么办。

我们在Sys_User实体类中加如Password属性

    public class Sys_User
{
[Key]
public int UserId { get; set; }
public string UserName { get; set; }
public string Password { get; set; }
}

然后运行,报错:Additional information: The model backing the 'MyContext' context has changed since the database was created. Consider using Code First Migrations to update the database 。

然后我们手动去修改数据库表结构,发现依然不行,报一样的错误。就是表__MigrationHistory在作怪。

正确的做法是:

在Nuget Manager下运行Enable-Migrations

Each package is licensed to you by its owner. Microsoft is not responsible for, nor does it grant any licenses to, third-party packages. Some packages may include dependencies which are governed by additional licenses. Follow the package source (feed) URL to determine any dependencies.

Package Manager Console Host Version 2.7.40911.287

Type 'get-help NuGet' to see all available NuGet commands.

PM> Enable-Migrations

之后在Solution中会生成Migrations文件夹,里面的文件看一下即可,不用太关心。

继续在Nuget Manager下运行Add-Migrations,并输入Name:AddTest后,会看到在Migrations文件夹下产生一笔新的文件:201603220556041_AddTest.cs

namespace ConsoleApplication1.Migrations
{
using System;
using System.Data.Entity.Migrations; public partial class AddTest : DbMigration
{
public override void Up()
{
AddColumn("dbo.Sys_User", "Password", c => c.String());
} public override void Down()
{
DropColumn("dbo.Sys_User", "Password");
}
}
}

继续在Nuget Manager下运行update-database,运行后可发现数据库Sys_User表中已生成Password字段,至此迁移结束。

注意看数据库中的__MigrationHistory表,此时多了一笔数据,就是刚刚的迁移记录!!

MigrationId
-------------------------------
201603220546077_InitialCreate
201603220556041_AddTest

(2 row(s) affected)

EF 示例的更多相关文章

  1. 微软官方 Github 上的 EF 示例项目 EntityFramework.Docs

    项目地址:https://github.com/aspnet/EntityFramework.Docs/tree/master/samples/core 谢谢浏览!

  2. WPF+MVVM+EF示例1

    实现了那些功能,先看看效果图: 项目工程目录: 接下来开始具体的步骤: 第一步:在VS中新建工程 第二步:使用NuGet 安装EntityFramework 第三步:使用NuGet 安装EntityF ...

  3. 【函数】oracle translate() 详解+实例

      一.语法: TRANSLATE(string,from_str,to_str) 二.目的 返回将(所有出现的)from_str中的每个字符替换为to_str中的相应字符以后的string.TRAN ...

  4. 【JAVAWEB学习笔记】25_Linux基础

    Linux基础 学习目标 1.了解Linux的简介与安装 2.掌握Linux常用的命令 3.掌握Linux系统上JDK.Mysql.Tomcat的安装 一.Linux的简介 1.Linux的概述 Li ...

  5. Linux 常用命令之二

    整理以前学习Linux的笔记. 查找目录.查看当前所在路径.新建文件.查看文件内容.修改文件内容.压缩文件操作.搜索命令.管道命令.查看进程.终止进程.查看端口. 7,命令find--查找目录 fin ...

  6. 一些常用的基础Linux操作指令

    复习的时候顺便分享我学的知识,虽不是什么牛的技术分享,只是一些基础,基础打好了技术慢慢就提高了!一起加油一起共勉! 具体的vi和vim命令集太多了,以后的随笔我也会分享出来,没必要全记住,记住常用的就 ...

  7. 【JAVAWEB学习笔记】26_Linux基础:简介安装、常用命令和JDK、Mysql、Tomcat的安装

    Linux基础 学习目标 1.了解Linux的简介与安装 2.掌握Linux常用的命令 3.掌握Linux系统上JDK.Mysql.Tomcat的安装 一.Linux的简介 1.Linux的概述 Li ...

  8. Linux的基本命令总结

    服务器版的Linux安装完毕了,但没有图形化界面,我们只能通过控制台去操作系统,我们就要使用类似DOS命令的Linux命令去操作系统,那么下面我们就进行Linux的命令的学习.Linux命令成百上千, ...

  9. Linux学习记录(一)

    1.Linux的简介 1.1.Linux的概述 Linux是基于Unix的开源免费的操作系统,由于系统的稳定性和安全性几乎成为程序代码运行的最佳系统环境.Linux是由Linus Torvalds(林 ...

随机推荐

  1. mongo

    最近一直在用mongodb,有时候会需要用到统计,在网上查了一些资料,最适合用的就是用aggregate,以下介绍一下自己运用的心得.. 别人写过的我就不过多描述了,大家一搜能搜索到N多一样的,我写一 ...

  2. volatile简介

    volatile简介 java语言提供了一种稍弱的内存同步机制,即volatile变量.用来确保将变量的更新操作通知到其它线程,保证了新值能立即同步到主内存,以及每次使用前立即从内存刷新.当变量声明为 ...

  3. C++ STL算法系列2---find ,find_first_of , find_if , adjacent_find的使用

    一.find运算 假设有一个int型的vector对象,名为vec,我们想知道其中是否包含某个特定值. 解决这个问题最简单的方法时使用标准库提供的find运算: 1 // value we'll lo ...

  4. 常用IT类英文词汇 - 1

    作为IT学生以及将来打算从事IT行业的人, 我们在开发时少不了要去阅读英文文档, 在面试及工作中也会涉及到相关的英文词汇, 因此具备一定的英语水准是必须的. 这里我就把我在学习中所遇到的英文词汇记录下 ...

  5. qt 程序启动参数 -qws  (转至 MrTXK

    运行嵌入式程序 在嵌入式QT版本中,程序需要服务器或自己作为服务器程序.服务器程序构造的方法是构造一个QApplication::GuiServe类型的QApplication对象.或者使用-qws命 ...

  6. 团队开发——冲刺2.b

    冲刺阶段二(第二天) 1.昨天做了什么? 收集游戏图片:开始.暂停.继续.重新开始.退出……为了界面的后期美工做准备. 2.今天准备做什么? 把“开始游戏”.“退出游戏”.“取消”等文字按钮加工成游戏 ...

  7. How to implement updatable view with NHibernate

    see : http://msdn.microsoft.com/en-us/library/ms187956.aspx(The constrains of creation updatable vie ...

  8. Linux线程-pthread_kill

    该函数可以用于向指定的线程发送信号: int pthread_kill(pthread_t threadId,int signal); 如果线程内不对信号进行处理,则调用默认的处理程式,如SIGQUI ...

  9. 将Rmarkdown文件转为pdf文件

    knitr包只能够将R markdown文件转为html格式,若想要将其转化为pdf格式,还要安装另一个包 # Install and load package install.packages(&q ...

  10. oc实例变量初始化方法

    1 使用实例setter方法 默认初始化方法 + setName:xxx setAge:xxx 2 使用实例功能类方法,默认初始化方法 + setName:xxx age:xxx3 使用实例初始化方法 ...