一. 简介

  EF连接数据库有三种模式,分别是DBFirst、ModelFirst、CodeFirst,分别适用于不同的开发场景。

  该章节,将主要介绍EF的DBFirst连接SQLServer数据库和MySql数据库两种操作方式

  该模式在EF中出现的出现的最早,符合我们的传统开发模式,先设计数据库→然后在代码通过EF与数据库建立映射关系,是EF最早的一种使用方式,使用广泛.以数据库为驱动,生成实体模型,从而驱动整个开发流程。

(1). 优点:操作简单,直接通过可视化界面与数据库表(存储过程、视图等)建立映射关系,省去自己建立表实体的繁琐步骤.
 (2). 缺点:与表依赖太强,而且实体是通过T4模板生成的,无法自己根据实际需要来修改,并且一旦数据库修改,就需要重新映射edmx文件了.
 (3). 特点:通过T4模板来生成EF上下文和实体模型; 并且可以直接将存储过程或视图映射到生成的上下文中,通过EF上下文直接调用存储过程(详见 EF调用存储过程章节)

二. DBFirst连接SQLServer数据库

1. 选择ADO.NET数据实体模型

2. 选择模型内容:来自数据库的EF设计器

3. 设置服务器及连接字符串

4. 选择数据库的连接并且可以设置配置文件的名称

5. 选择要映射的表、视图、存储过程和函数,完成映射

6. 如果框架是分层的,需要将生产的连接数据库的字符串,复制到主程序的配置文件中

三. DBFirst连接MySQL数据库

 事先准备和注意事项:

步骤:

①:安装mysql-connector-net-6.9.9.msi,下载地址:https://dev.mysql.com/downloads/connector/net/ (vs2012-vs2017通用)

②:安装mysql-for-visualstudio-1.2.7.msi,下载地址:https://dev.mysql.com/downloads/windows/visualstudio/ (vs2012-vs2017通用)

③:连接远程服务器需要先在对应数据库服务器上对访问外来的ip和用户名、密码进行授权。

如:GRANT ALL PRIVILEGES ON *.* TO 'root'@'39.88.192.171' IDENTIFIED BY '123456' WITH GRANT OPTION;

表示:ip为39.88.192.171的root用户、密码为123456可以远程访问该数据库服务器

④:安装常规的DBFist模式进行连接即可,但连接界面要选择MySQL对应的界面。

 特别注意:在使用该模式的时候,会遇到这么几个烦人的情况,如果该项目中已经引用的了EF的程序集,在可视化界面无法选择EF版本。

 但是如果你把引用的程序集删了,可视化界面只能选择EF5.0

所以解决方案:

步骤①:如果引用了EF的程序集,先删掉,然后用可视化界面把EF5.0添加进来,然后在使用Nuget把EF5.0卸载掉。

步骤②:通过nuget一次添加 EF6.x、MySql.Data、MySql.Data.Entity、MySql.Web 程序集的引用.

步骤③:如果是分层开发,不但要向封装层添加引用,还要想主程序层添加EF6.x、MySql.Data、MySql.Data.Entity、MySql.Web 程序集的引用.

步骤④:主程序层配置文件中<entityFramework>→<providers>节点下添加:

<provider invariantName="MySql.Data.MySqlClient" type="MySql.Data.MySqlClient.MySqlProviderServices, MySql.Data.Entity.EF6"></provider>

如果是通过Nuget添加的程序集,检查一下是否已经自动添加了,避免重复添加的情况

链接步骤:使用MySQL的客户端界面

代码测试,和SQLServer写法并没有什么两样

      private static void NewMethod()
{
Console.WriteLine("-----------------------1. DBFirst模式连接MySQL数据库-------------------------------");
using (DbContext db = new mysqldb1Entities())
{
//1.1 测试查询 (正常)
//List<tbb1> tList = db.Set<tbb1>().ToList();
//foreach (var item in tList)
//{
// Console.WriteLine("id为:{0},name为:{1}", item.id, item.name);
//} //1.2 测试一下大数据 (正常)
Stopwatch watch = Stopwatch.StartNew();
List<tbb1> tList2 = new List<tbb1>();
for (int i = ; i < ; i++)
{
tbb1 t = new tbb1();
t.id = Guid.NewGuid().ToString("N");
t.name = "t" + i;
tList2.Add(t);
}
db.BulkInsert(tList2);
watch.Stop();
Console.WriteLine("{0}条数据耗时:{1}", , watch.ElapsedMilliseconds);
}
}
#endregion

第十一节: EF的三种模式(一) 之 DBFirst模式(SQLServer和MySQL两套方案)的更多相关文章

  1. ASP.NET MVC深入浅出(被替换) 第一节: 结合EF的本地缓存属性来介绍【EF增删改操作】的几种形式 第三节: EF调用普通SQL语句的两类封装(ExecuteSqlCommand和SqlQuery ) 第四节: EF调用存储过程的通用写法和DBFirst模式子类调用的特有写法 第六节: EF高级属性(二) 之延迟加载、立即加载、显示加载(含导航属性) 第十节: EF的三种追踪

    ASP.NET MVC深入浅出(被替换)   一. 谈情怀-ASP.NET体系 从事.Net开发以来,最先接触的Web开发框架是Asp.Net WebForm,该框架高度封装,为了隐藏Http的无状态 ...

  2. 第十四节: EF的三种模式(四) 之 原生正宗的 CodeFirst模式的默认约定

    一. 简介 1. 正宗的CodeFirst模式是不含有edmx模型,需要手动创建实体.创建EF上下文,然后生成通过代码来自动映射生成数据库. 2. 旨在:忘记SQL.忘记数据库. 3. 三类配置:On ...

  3. 第七节: EF的三种事务的应用场景和各自注意的问题(SaveChanges、DBContextTransaction、TransactionScope)

    一. 什么是事务 我们通俗的理解事务就是一系列操作要么全部成功.要么全部失败(不可能存在部分成功,部分失败的情况). 举一个事务在我们日常生活中的经典例子:两张银行卡(甲.乙),甲向乙转钱,整个过程需 ...

  4. 第十节: EF的三种追踪实体状态变化方式(DBEntityEntry、ChangeTracker、Local)

    一. 简介 我们在前面章节介绍EF基本增删改的时候,曾说过EF的SaveChanges()方法,会一次性的将所有的实体的状态变化统一提交到数据库,那么你是否想过EF的实体会有哪些状态变化呢?什么原因会 ...

  5. 第四节: EF调用存储过程的通用写法和DBFirst模式子类调用的特有写法

    一. 背景 上一个章节,介绍了EF调用两类SQL语句,主要是借助 ExecuteSqlCommand  和 SqlQuery 两个方法来完成,在本章节主要是复习几类存储过程的写法和对应的EF调用这几类 ...

  6. 第十三节: EF的三种模式(三) 之 来自数据库的CodeFirst模式

    一. 简介 [来自数据库的Code First模式]实质上并不是CodeFirst模式,而是DBFirst模式的轻量级版本,在该模式中取消了edmx模型和T4模板,直接生成了EF上下文和相应的类,该模 ...

  7. Spark部署三种方式介绍:YARN模式、Standalone模式、HA模式

    参考自:Spark部署三种方式介绍:YARN模式.Standalone模式.HA模式http://www.aboutyun.com/forum.php?mod=viewthread&tid=7 ...

  8. EF的三种模式

    1.DateBase First(数据库优先) 2.Model First(模型优先) 3.Code First(代码优先) 当然,如果把Code First模式的两种具体方式独立出来,那就是四种了. ...

  9. Entity Framework 5.0系列之EF概览-三种编程方式

    概述 在开发面向数据的软件时我们常常为了解决业务问题实体.关系和逻辑构建模型而费尽心机,ORM的产生为我们提供了一种优雅的解决方案.ADO.NET Entity Framework是.NET开发中一种 ...

随机推荐

  1. PE文件格式对定位病毒特征码的作用

    本文主要从杀毒软件查杀病毒的原理出发,分析PE文件格式在杀毒软件定位病毒特征码中的作用.杀毒软件通过快速准确定位病毒特征码,对伪装,隐藏,变种病毒进行查杀. 一.杀毒软件查杀病毒的原理概述 对于操作系 ...

  2. 2017 百度杯丶二月场第一周WP

    1.祸起北荒 题目: 亿万年前 天子之子华夜,被父神之神末渊上神告知六荒十海之北荒西二旗即将发生一场"百度杯"的诸神之战 他作为天族的太子必须参与到此次诸神之战定六荒十海 华夜临危 ...

  3. js 页面history.back()返回上一页,ios 不重新加载ready的解决办法

    参考自 http://blog.csdn.net/hbts_901111zb/article/details/76691900 项目中,主页面有很多输入字段,当由主页跳转到子页面, 将子页面的字段 s ...

  4. 数据库的设计:深入理解 Realm 的多线程处理机制

    你已经阅读过 Realm 关于线程的基础知识.你已经知道了在处理多线程的时候你不需要关心太多东西了,因为强大的 Realm 会帮你处理好这些,但是你还是很想知道更多细节…… 你想知道在 Realm 的 ...

  5. Vuex初级入门及简单案例

    1.为什么要使用Vuex? (1)方便所有组件共享信息,方便不同组件共享信息. (2)某个组件需要修改状态和需求.   2.状态有哪些? (1)组件内部定义的data状态(通过组件内部修改) (2)组 ...

  6. day17-异常处理

    今天的内容比较少,只是单独的异常处理 开始今日份整理 1.异常 定义:异常时错误发生的信号,一旦出错,并且程序没有处理这个错误,就会抛出异常,并且程序会运行中止 2.异常的分类 2.1语法错误:pyt ...

  7. Android开发欢迎页点击跳过倒计时进入主页

    没点击跳过自然进入主页,点击跳过之后立即进入主页     1.欢迎页布局activity_sp.xml放一张背景图(图片随你便啦)再放一个盛放倒计时的TextView   <?xml versi ...

  8. D. Concatenated Multiples(离线处理)

    思路:直接离线处理出每个ai 的10倍, 100倍, 1000倍的mod k 后的数值的个数,使用map<int,int >ss[12]存储, ss[x][y]表示 (ai*10x)%k= ...

  9. 性能测试中的最佳用户数、最大用户数、TPS、响应时间、吞吐量和吞吞吐率

    一:最佳用户数.最大用户数 转:http://www.cnblogs.com/jackei/archive/2006/11/20/565527.html 二:  事务.TPS 1:事务:就是用户某一步 ...

  10. 玩转PIL库

    1.安装pillow库: 在cmd下,输入简单的命令: pip install pillow  即可安装pillow库. 2.PIL库的简介: 1. PIL库主要有2个方面的功能: (1) 图像归档: ...