EF(一)DB First
“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的更多相关文章
- .net core 2.2 EF oracle db first
Nuget控制台: Install-Package log4net Install-Package Newtonsoft.Json Install-Package Autofac Install-Pa ...
- EF查询之性能优化技巧
上一篇:EF使用CodeFirst方式生成数据库&技巧经验 前言 EF相信大部分同学都已经经常使用了,可是你的查询高效吗? 今天我就以个人使用经验来讲讲在使用EF做查询的时候大家都容易忽略的性 ...
- 1_MVC+EF+Autofac(dbfirst)轻型项目框架_core层(以登陆为例)
前言 在上一篇0_MVC+EF+Autofac(dbfirst)轻型项目框架_基本框架中,我已经介绍了这个轻型框架的层次结构,在下面的这篇文章中,我将以教师登陆功能为例,具体来扩充下我的core层的代 ...
- EF框架学习
简称EF,ADO.NET Entity Framework是微软以ADO.NET为基础所发展出来的对象关系对应(O/R Mapping)解决方案,是微软的一个ORM(面向对象的对象模型和关系型数据库的 ...
- ORM框架 EF - code first 的封装
Code first 是Microsoft Entity Framework中的一种模式,CodeFirst不会有可视化的界面来进行拖动编辑DataBase-Entity,但会以一个类来进行对数据表关 ...
- EF Dal通用类
一个通用的ef dal处理类是非擦汗那个提高工作效率的 using System; using System.Collections.Generic; using System.Data.Enti ...
- EF通用数据层封装类(支持读写分离,一主多从)
浅谈orm 记得四年前在学校第一次接触到 Ling to Sql,那时候瞬间发现不用手写sql语句是多么的方便,后面慢慢的接触了许多orm框架,像 EF,Dapper,Hibernate,Servic ...
- 如何用VS EF连接 Mysql,以及执行SQL语句 和存储过程?
VS2013, MySQL5.7.18 , MySQL5.7.14 执行SQL语句: ztp_user z = new ztp_user(); object[] obj = new object[] ...
- ORM框架 EF - code first 的封装 优化一
上一节我们讲到对EF(EntityFramework)的初步封装,任何事情都不可能一蹴而就,通过大量的实际项目的实战,也发现了其中的各种问题.在这一章中,我们对上一章的EF_Helper_DG进行优化 ...
- .Net中EF通用数据层小结
增删改查: using System; using System.Collections.Generic; using System.Data; using System.Data.Entity; u ...
随机推荐
- bzoj5397 circular 随机化(
题目大意 给定一个环,环上有一些线段,试选出最多的线段 题解: 提醒:这可能是一篇非常欢乐的题解 我们考虑倍长环,然后断环为链 我们考虑枚举开头的线段,然后做一次贪心 这样子的复杂度根据实现的不同是\ ...
- [CF542D]Superhero's Job
[CF542D]Superhero's Job 题目大意: 定义函数 \[ J(x) = \sum_{\substack{1 \leq k \leq x \\ k \mid x \\ \gcd \le ...
- LOJ 6270
最近(一直)有点(很)蠢 按照区间大小排序做区间包含多少区间的话 只用考虑 左端点比当前左端点小的和右端点比当前右端点大的,因为不可能同时满足 关于K,就在做到K的时候减一下就好了,一直傻逼在这了 # ...
- 5. Spring 通过 XML 配置 bean (进阶)
1. 设置 bean 的作用域 当通过 Spring IOC 容器创建 bean 实例的时候,不仅可以完成 bean 的实例化,也可以为 bean 指定特定的作用域,Spring 支持以下 5 种作用 ...
- angular.identity()
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- [LeetCode] Design Circular Queue 设计环形队列
Design your implementation of the circular queue. The circular queue is a linear data structure in w ...
- 解析Json文件
一: /** * 把json文件读取到内存中 * * @throws IOException */ public String getFile(String filePath) throws IOEx ...
- centos中安装配置nginx完成之后主机无法访问
原因 VMware中安装centos7,安装配置完成nginx后,主机无法访问.虚拟机没有放行Nginx默认端口80. 解决办法 首先:开启 web 端口 firewall-cmd --permane ...
- 关于eclipse的Progress一直跳转的解决方案
下载eclipse编程,发现了一个问题:执行main方法第二次console打印不出数据,后发现Progress一直跳转,而且非常多进度条在运行,关闭后第一次执行没问题,第二次问题重复出现. 有幸看到 ...
- 工具包分享-常用工具。by-某某
下载地址: 链接:http://pan.baidu.com/s/1hsseqm4 密码:a6rc 里面的工具全部来自互联网,本人不是工具的生产者,只是它的收集工. 都是一些很常用,顺手的工具,仅用于技 ...