Entity Framework(EF的Code First方法)
EntityFramework,是Microsoft的一款ORM(Object-Relation-Mapping)框架。同其它ORM(如,NHibernate,Hibernate)一样,
一是为了使开发人员以操作对象的方式去操作关系型数据表。
二是为了屏蔽底层不同厂商的数据库,开发人员面向ORM框架编写数据的CRUD(Create,Retrieve,Update,Delete)操作,再由ORM框架将这些操作翻译成不同数据库厂商的语言。
从EF 4.X开始支持三种构建方法:1. Database First方法。2.Model First方法。3.Code First 方法。

本次测试以Visual Studio2013 / MS Sql Server2012 / Entity Framework 6.X 测试EF
Code First Demo【此时数据库和表格都已经存在,为了在原有项目中引入EF,需要使用这种方式】
【关键:上下文,实体类的约束及关系】
//MS SQL Server连接字符串
//connectionString="Data Source=(local);Initial Catalog=EFTest;User Id=sa;Password=123456;" providerName="System.Data.SqlClient"
<connectionStrings>
<add name="EFTest" connectionString="Data Source=(local);Initial Catalog=EFTest;User Id=sa;Password=123456;" providerName="System.Data.SqlClient"></add>
</connectionStrings>
原有项目中,已经有了模型类,所以不再重新生成模型类
操作步骤:
1>引入程序集EntityFramework.dll,System.Data.Entity.dll
2>在配置文件中 写连接字符串
3>创建模型类(如果项目中有模型类,则只需要维护关系)
通过导航属性来表示类的关系,注意:导航属性设置成virtual,
特性维护:Table,Key,ForeignKey
4>创建上下文类,继承自DbContext
调用父类构造方法,传递连接字符串"name=***"
5>根据类型创建数据库表
Context1 context = new Context1();
使用context.Database.CreateIfNotExists();完成数据库中表的创建;
调用context.SaveChanges()方法完成保存。
1:打开SQLServer2012,使用下面SQL文本创建MyFirstModelFirstEF数据库
create database EFTest
on primary
(
name='EFTest.mdf',
--修改为自己电脑上SQL DB路径
filename='D:\yangZ_MSSQL\EFTest.mdf',
size=5mb,
maxsize=100mb,
filegrowth=10%
)
log on
(
name='EFTest_log.ldf',
--修改为自己电脑上SQL DB路径
filename='D:\yangZ_MSSQL\EFTest_log.ldf',
size=2mb,
maxsize=100mb,
filegrowth=5mb
)
go
2:新建ConsoleApplication应用程序EFCodeFirstDemo

3:引入程序集EntityFramework.dll,System.Data.Entity.dll (默认找不到引用EntityFramework.dll)
3.1:可以通过NuGet来获取 [工具-->库程序包管理器-->程序包管理器控制台],Ps:这种方式要求电脑必须联网
Install-Package EntityFramework -Version 6.0.2
Install-Package EntityFramework -Pre (表示最新)
Uninstall-Package EntityFramework -Version 6.1.0
3.2:拷贝现有EF项目中的EntityFramework.dll文件
3.3:可以通过ModelFirst/DatabaseFirst(不添加任何表格)引入dll,然后删除Model.edmx文件
在EFCodeFirstDemo上 右键-->新建-->新建项-->数据-->ADO.NET实体数据模型,选择从数据库生成/空模型,然后点击完成

4:在配置文件中 写连接字符串
<connectionStrings>
<add name="EFTest" connectionString="Data Source=(local);Initial Catalog=EFTest;User Id=sa;Password=123456;" providerName="System.Data.SqlClient"></add>
</connectionStrings>
5:创建模型类(如果项目中有模型类,则只需要维护关系)
通过导航属性来表示类的关系,注意:导航属性设置成virtual,
特性维护:Table,Key,ForeignKey
ContactInfo.cs
using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
using System.Linq;
using System.Text;
using System.Threading.Tasks; namespace EFCodeFirstDemo
{
//Table是在 System.ComponentModel.DataAnnotations.Schema
[Table("ContactInfo")]
public class ContactInfo
{
//Key 是在System.ComponentModel.DataAnnotations
[Key]
public int InfoId { get; set; } public string InfoName { get; set; } //ForeignKey 是在System.ComponentModel.DataAnnotations.Schema
[ForeignKey("ContactType")]
public int ContactTypeId { get; set; } public virtual ContactType ContactType { get; set; }
}
}
ContactType.cs
using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
using System.Linq;
using System.Text;
using System.Threading.Tasks; namespace EFCodeFirstDemo
{
//Table是在 System.ComponentModel.DataAnnotations.Schema
[Table("ContactType")]
public class ContactType
{
public ContactType()
{
this.ContactInfo = new HashSet<ContactInfo>();
} //Key 是在System.ComponentModel.DataAnnotations
[Key]
public int TypeId { get; set; } public string TypeTitle { get; set; } public virtual ICollection<ContactInfo> ContactInfo { get; set; }
}
}
通过实体框架 Code First 建立新数据库 链接: http://pan.baidu.com/s/1qYBZiCc 密码: 5r4a
6:创建上下文类,继承自DbContext
调用父类构造方法,传递连接字符串"name=***"
6.1:在EFCodeFirstDemo project项目 右键-->添加-->类 Context1.cs
using System;
using System.Collections.Generic;
using System.Data.Entity;
using System.Linq;
using System.Text;
using System.Threading.Tasks; namespace EFCodeFirstDemo
{
public class Context1 : DbContext
{
public Context1()
: base("name=EFTest")
{
} public virtual DbSet<ContactType> ContactType { get; set; } public virtual DbSet<ContactInfo> ContactInfo { get; set; }
}
}

7:根据类型创建数据库表
Context1 context = new Context1();
使用context.Database.CreateIfNotExists();完成数据库中表的创建;
调用context.SaveChanges()方法完成保存。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks; namespace EFCodeFirstDemo
{
class Program
{
static void Main(string[] args)
{
Context1 context = new Context1();
//在现有链接数据库中 ,若当前实体模型对应的数据库不存在,则创建,反之则不需要创建
context.Database.CreateIfNotExists();
context.SaveChanges();
}
}
}
此时对应MS SQL Server数据库为:

【未完,待续】
Entity Framework(EF的Code First方法)的更多相关文章
- Entity Framework(EF的Model First方法)
EntityFramework,是Microsoft的一款ORM(Object-Relation-Mapping)框架.同其它ORM(如,NHibernate,Hibernate)一样, 一是为了使开 ...
- Entity Framework(EF的Database First方法)
EntityFramework,是Microsoft的一款ORM(Object-Relation-Mapping)框架.同其它ORM(如,NHibernate,Hibernate)一样, 一是为了使开 ...
- 【极力分享】[C#/.NET]Entity Framework(EF) Code First 多对多关系的实体增,删,改,查操作全程详细示例【转载自https://segmentfault.com/a/1190000004152660】
[C#/.NET]Entity Framework(EF) Code First 多对多关系的实体增,删,改,查操作全程详细示例 本文我们来学习一下在Entity Framework中使用Cont ...
- ASP.NET Core 开发-Entity Framework (EF) Core 1.0 Database First
ASP.NET Core 开发-Entity Framework Core 1.0 Database First,ASP.NET Core 1.0 EF Core操作数据库. Entity Frame ...
- Visual Studio Entity Framework (EF) 生成SQL 代码 性能查询
Visual Studio Entity Framework (EF) 生成SQL 代码 性能查询 SQL 中,有SQL Server Profiler可以用来查询性能以及查看外部调用的SQL ...
- [转]Using Entity Framework (EF) Code-First Migrations in nopCommerce for Fast Customizations
本文转自:https://www.pronopcommerce.com/using-entity-framework-ef-code-first-migrations-in-nopcommerce-f ...
- Entity Framework工具POCO Code First Generator的使用
在使用Entity Framework过程中,有时需要借助工具生成Code First的代码,而Entity Framework Reverse POCO Code First Generator是一 ...
- Entity Framework工具POCO Code First Generator的使用(参考链接:https://github.com/sjh37/EntityFramework-Reverse-POCO-Code-First-Generator)
在使用Entity Framework过程中,有时需要借助工具生成Code First的代码,而Entity Framework Reverse POCO Code First Generator是一 ...
- ASP.NET Core 开发 - Entity Framework (EF) Core
EF Core 1.0 Database First http://www.cnblogs.com/linezero/p/EFCoreDBFirst.html ASP.NET Core 开发 - En ...
随机推荐
- vue 组件 子向父亲通信用自定义方法用事件监听
<!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>T ...
- vue 笔记1
created 钩子可以用来在一个实例被创建之后执行代码: new Vue({ data: { a: 1 }, created: function () { // `this` 指向 vm 实例 co ...
- 深入探索.NET内部了解CLR如何创建运行时对象
前言 SystemDomain, SharedDomain, and DefaultDomain. 对象布局和内存细节. 方法表布局. 方法分派(Method dispatching). 因为公共语言 ...
- Kafka日志存储原理
引言 Kafka中的Message是以topic为基本单位组织的,不同的topic之间是相互独立的.每个topic又可以分成几个不同的partition(每个topic有几个partition是在创建 ...
- Android CollapsingToolbarLayout
第一次看到这种用户体验是在Google Play Store App的应用详情的Activity中. 大的Banner图,能第一时间吸引用户的眼球,用不一样的Banner大图更具个性化的展示内容.图总 ...
- BZOJ3142 HNOI2013数列(组合数学)
考虑差分序列.每个差分序列的贡献是n-差分序列的和,即枚举首项.将式子拆开即可得到n*mk-1-Σi*cnt(i),cnt(i)为i在所有差分序列中的出现次数之和.显然每一个数出现次数是相同的,所以c ...
- selenium实战之斗鱼弹幕
python3.6.selenium.chromedriver 先上代码 from selenium import webdriver from time import sleep driver=we ...
- Life Forms POJ - 3294(不小于k个字符串中的最长子串)
题意: 求不小于字符串一半长度个字符串中的最长字串 解析: 论文题例11 将n个字符串连起来,中间用不相同的且没有出现在字符串中的字符隔开, 求后缀数组, 然后二分答案变为判定性问题, 然后判断每组的 ...
- 应该更新的Java知识之常用程序库
摘自:http://www.blogbus.com/dreamhead-logs/226738702.html 在很多人眼中,Java已经是一门垂垂老矣的语言,但并不妨碍Java世界依然在前进.如果你 ...
- BZOJ2525 [Poi2011]Dynamite 【二分 + 贪心】
题目链接 BZOJ2525 题解 就是要求所有有炸弹的点到点燃点距离最大值最小 显然二分答案距离\(D\) 然后按深度排序,贪心点燃当前没覆盖的深度最深的点往上第\(D\)层的点 每覆盖一个点要标记其 ...