“Database First”模式我们称之为“数据库优先”,前提是你的应用已经有相应的数据库,你可以使用EF设计工具根据数据库生成数据数据类,你可以使用Visual Studio模型设计器修改这些模型之间对应关系。

一、创建ADO.NET实体集

省略其他操作截图,创建成功,生成ModelEF.edmx。介绍生成的模型中的文件。

二、介绍模型中的文件

直接双击打开ModelEF.edmx文件,显示的是你创建实体集时选择的数据库表的属性图:

展开后有个以.tt的文件,这是T4模版文件,这些模版文件用于生成数据库上下文和实体集,双击可以查看:

数据库上下文,连接数据库全靠他了:

其中构造函数的base里的name属性是你连接的数据库配置名称,在你的.config文件中有:

另一个.tt文件则是生成实体类的模版文件:

三、声明数据库上下文,进行CRUD操作

 //1.声明一个EF上下文
EFDemoEntities dbContext = new EFDemoEntities();

四、查询

 EFDemoEntities dbContext = new EFDemoEntities();
foreach (var user in dbContext.T_User)
{
Console.WriteLine(user.NAME);
}

linq查询

 #region linq查询
var temp = from u in dbContext.T_User
where u.ID >
select u;
foreach (var u in temp)
{
Console.WriteLine(u.NAME);
}
#endregion

五、增

利用实体对象,主键如果是自增,可以不定义

 .声明一个EF上下文
EFDemoEntities dbContext = new EFDemoEntities();
.声明一个User实体
T_User user = new T_User();
user.LOGINNAME = "";
user.MAIL = "2@qq.com";
user.NAME = "";
user.PASSWORD = "";
user.PHONE = "";
user.ID = ;
.告诉EF对上面的实体进行一个插入操作
dbContext.T_User.Add(user);
.告诉上下文把实体的变化保存到数据库里
dbContext.SaveChanges();

六、删除

 //1.声明一个EF上下文
EFDemoEntities dbContext = new EFDemoEntities();
//2.声明一个User实体
T_User user = new T_User();
//user.LOGINNAME = "2";
//user.MAIL = "2@qq.com";
//user.NAME = "22";
//user.PASSWORD = "000000";
//user.PHONE = "12345678";
user.ID = ; //删除只要定义主键就好
//3.告诉EF对上面的实体进行一个删除操作
dbContext.Entry<T_User>(user).State = System.Data.EntityState.Deleted;
//4.告诉上下文把实体的变化保存到数据库里
dbContext.SaveChanges();

七、改

1.通过定义实体对象进行修改

 //1.声明一个EF上下文
EFDemoEntities dbContext = new EFDemoEntities();
//2.声明一个User实体
T_User user = new T_User();
user.LOGINNAME = "";
user.MAIL = "3@qq.com";
user.NAME = "";
user.PASSWORD = "";
user.PHONE = "";
user.ID = ; //修改必须指定主键
//3.告诉EF对上面的实体进行一个修改整条数据的操作
dbContext.Entry<T_User>(user).State = System.Data.EntityState.Modified;
//4.告诉上下文把实体的变化保存到数据库里
dbContext.SaveChanges();

2.指定修改字段

 //1.声明一个EF上下文
EFDemoEntities dbContext = new EFDemoEntities();
//2.声明一个User实体
T_User user = new T_User();
user.LOGINNAME = "";
user.MAIL = "3@enzemed.com";
user.NAME = "";
user.PASSWORD = "";
user.PHONE = "";
user.ID = ; //修改必须指定主键
//3.告诉EF对上面的实体进行某一列修改
dbContext.T_User.Attach(user);
dbContext.Entry<T_User>(user).Property<string>(p => p.MAIL).IsModified = true;
dbContext.Entry<T_User>(user).Property<string>(p => p.LOGINNAME).IsModified = true;
//4.告诉上下文把实体的变化保存到数据库里
dbContext.SaveChanges();

八、EntityState的几种状态

Detached:对象存在,但未由对象服务跟踪。在创建实体之后、但将其添加到对象上下文之前,该实体处于此状态,即对象与上下文处于分离状态;

Unchanged:自对象加载到上下文中后,或自上次调用 System.Data.Objects.ObjectContext.SaveChanges() 方法后,此对象尚未经过修改;

Added:对象已添加到对象上下文,但尚未调用 System.Data.Objects.ObjectContext.SaveChanges() 方法;

Deleted:使用 System.Data.Objects.ObjectContext.DeleteObject(System.Object) 方法从对象上下文中删除了对象;

Modified:对象已更改,但尚未调用 System.Data.Objects.ObjectContext.SaveChanges() 方法。

九、DbSet<TEntity>的Add和Attach

TEntity Add(TEntity entity);

将给定实体以 System.Data.EntityState.Added 状态添加到上下文中。保存更改后,“已添加”状态的实体将插入到数据库中。在保存更改后,对象状态将更改为System.Data.EntityState.Unchanged。

TEntity Attach(TEntity entity);

将给定实体以 System.Data.EntityState.Unchanged 状态附加到上下文中

十、Expression<Func<TEntity, TProperty>>

Func是定义委托,Expression是将委托的lamda表达式转换成sql语句。

EF(一)DB First的更多相关文章

  1. .net core 2.2 EF oracle db first

    Nuget控制台: Install-Package log4net Install-Package Newtonsoft.Json Install-Package Autofac Install-Pa ...

  2. EF查询之性能优化技巧

    上一篇:EF使用CodeFirst方式生成数据库&技巧经验 前言 EF相信大部分同学都已经经常使用了,可是你的查询高效吗? 今天我就以个人使用经验来讲讲在使用EF做查询的时候大家都容易忽略的性 ...

  3. 1_MVC+EF+Autofac(dbfirst)轻型项目框架_core层(以登陆为例)

    前言 在上一篇0_MVC+EF+Autofac(dbfirst)轻型项目框架_基本框架中,我已经介绍了这个轻型框架的层次结构,在下面的这篇文章中,我将以教师登陆功能为例,具体来扩充下我的core层的代 ...

  4. EF框架学习

    简称EF,ADO.NET Entity Framework是微软以ADO.NET为基础所发展出来的对象关系对应(O/R Mapping)解决方案,是微软的一个ORM(面向对象的对象模型和关系型数据库的 ...

  5. ORM框架 EF - code first 的封装

    Code first 是Microsoft Entity Framework中的一种模式,CodeFirst不会有可视化的界面来进行拖动编辑DataBase-Entity,但会以一个类来进行对数据表关 ...

  6. EF Dal通用类

    一个通用的ef  dal处理类是非擦汗那个提高工作效率的  using System; using System.Collections.Generic; using System.Data.Enti ...

  7. EF通用数据层封装类(支持读写分离,一主多从)

    浅谈orm 记得四年前在学校第一次接触到 Ling to Sql,那时候瞬间发现不用手写sql语句是多么的方便,后面慢慢的接触了许多orm框架,像 EF,Dapper,Hibernate,Servic ...

  8. 如何用VS EF连接 Mysql,以及执行SQL语句 和存储过程?

    VS2013, MySQL5.7.18 , MySQL5.7.14 执行SQL语句: ztp_user z = new ztp_user(); object[] obj = new object[] ...

  9. ORM框架 EF - code first 的封装 优化一

    上一节我们讲到对EF(EntityFramework)的初步封装,任何事情都不可能一蹴而就,通过大量的实际项目的实战,也发现了其中的各种问题.在这一章中,我们对上一章的EF_Helper_DG进行优化 ...

  10. .Net中EF通用数据层小结

    增删改查: using System; using System.Collections.Generic; using System.Data; using System.Data.Entity; u ...

随机推荐

  1. elasticsearch搜索框架的安装相关

    安装JAVA SE 百度一下JAVA SE,按照自己的平台,位数选择就是了, 这里遇到过一个坑,双击exe安装包一直无法打开jdk的安装,在任务管理器里面就一闪而过, 后来我卸载了所有JAVA的相关安 ...

  2. django——CRM项目

    1.引言 CRM,客户关系管理系统(Customer Relationship Management).企业用CRM技术来管理与客户之间的关系,以求提升企业成功的管理方式,其目的是协助企业管理销售循环 ...

  3. docker备份mongodb数据,导入导出

    场景:服务器要升级,之前在linux部署的mongodb没有用docker,升级后,mongodb要用docker部署,并将原有的mongodb数据导入到docker部署的mongodb中. 1.在l ...

  4. 网络流 最大流—最小割 之SAP算法 详解

    首先引入几个新名词: 1.距离标号: 所谓距离标号 ,就是某个点到汇点的最少的弧的数量(即边权值为1时某个点到汇点的最短路径长度). 设点i的标号为level[i],那么如果将满足level[i]=l ...

  5. 使用163.com邮箱发送邮件

    不要直接使用登录的密码,而是用配置中的授权码做为密码

  6. jsp模板继承

    jsp通过自定义标签实现类似模板继承的效果 关于标签的定义.注册.使用在上面文章均以一个自定义时间的标签体现,如有不清楚自定义标签流程的话请参考这篇文章 http://www.cnblogs.com/ ...

  7. ASPOSE.Word 开发资料整理

    1.总体说明:操作主要涉及两个对象Document及DocumentBuilder Document主要用来获取文档中的节点,DocumentBuilder主要用于实现文档内容的写入 doc_Oper ...

  8. 解析CommandMessage

    Json 解析: void CommandMessage::ParseCmdBody() { try { Json::Reader reader; Json::Value root; if (!rea ...

  9. swust oj 971

    统计利用先序遍历创建的二叉树的深度 10000(ms) 10000(kb) 3331 / 8436 利用先序递归遍历算法创建二叉树并计算该二叉树的深度.先序递归遍历建立二叉树的方法为:按照先序递归遍历 ...

  10. disconf安装问题

    安装参考文档:https://blog.csdn.net/fengyao1995/article/details/66491226 主要说说遇到的几个问题 1.在步骤6构建的时候,用jdk1.8,进行 ...