“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. (三)ajax请求不同源之cors跨域

    一.基本原理 CORS是一个W3C标准,全称是"跨域资源共享"(Cross-origin resource sharing)它允许浏览器向跨源服务器,发出 XMLHttpReque ...

  2. Python学习——python的常用模块

    模块:用一堆代码实现了某个功能的代码集合,模块是不带 .py 扩展的另外一个 Python 文件的文件名. 一.time & datetime模块 import time import dat ...

  3. java 多态 向上 向下转型

    向上转型 将子类对象当作父类对象     子类对象------>父类对象 先实例化子类 父类 父类对象 = 子类实例 package test2; class Father{ public vo ...

  4. 2017 United Kingdom and Ireland Programming Contest (UKIEPC 2017)

    A. Alien Sunset 暴力枚举答案即可. #include<cstdio> int n,i,mx; struct P{ int h,r,t; bool night(int x){ ...

  5. 使用Callable接口创建线程和使用线程池的方式创建线程

    1.使用Callable接口的方式实现多线程,这是JDK5.0新增的一种创建多线程的方法 package com.baozi.java2; import java.util.concurrent.Ca ...

  6. java列表数据基本操作

    列表数据组基本的增删改查 package cn.edu.fhj.day002; import java.util.ArrayList; public class ArrList { // 定义一个主函 ...

  7. centos7.4安装redis

    参考连接 https://blog.csdn.net/qq_19399235/article/details/78313633/

  8. [LeetCode] Jewels and Stones 珠宝和石头

    You're given strings J representing the types of stones that are jewels, and S representing the ston ...

  9. 剑指offer——python【第60题】把二叉树打印成多行

    题目描述 从上到下按层打印二叉树,同一层结点从左至右输出.每一层输出一行.#类似于二维列表[[1,2],[4,5]] 解题思路 其实这倒题和其他类似的题有所区别,这里是分层打印,把每层的节点值放在同一 ...

  10. Python自学知识点----Day03

    cd指令说明 1).作用:切换工作目录. 2).   命令(注意空格)         含义 cd ~===cd             回到家目录 cd .                     ...