【EF 1】EF实体框架 原理+实例

2024-08-25 22:18
文章标签 原理 实例 框架 实体 ef

本文主要是介绍【EF 1】EF实体框架 原理+实例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、知识回顾

到目前为止,自己学到的链接数据库操作已经经历了几个阶段,分别是:学生信息管理和(第一次)机房收费时的直接连接数据库操作表格,然后是机房个人重构中应用的操作实体,在其中还利用了一个很重要的帮助类:SQLHelper。

 

 

在这个转变中,已经逐步由面向过程转向面向对象,但在分层操作实体的过程中,由于数据库的设计不很完美,有时候需要修改数据库设计,或者需要更改实体。每次遇到这样的事儿,就脑袋疼,因为数据库和实体必须要对应起来,不然问题就越改越大了。
那么怎样解决这一问题呢?最近学习了一个EF实体框架知识,解决了这一问题。

 

 

首先,回顾一下这之前的数据库链接操作。也就是运用ADO.NET进行操作,主要经历5个步骤:建立连接—打开—创建命令—执行—关闭。如:

 

<span style="font-size:18px;"><span style="font-family:KaiTi_GB2312;font-size:24px;"> private void button1_Click(object sender, EventArgs e){string conStr = @"server=.;uid=sa;pwd=123456;database=shoppingBus";//连接字符串SqlConnection sqlconnection = new SqlConnection(conStr);//建立连接sqlconnection.Open();//打开链接string str = "select * from petType";DataTable dt = new DataTable();SqlDataAdapter sqldataadapter = new SqlDataAdapter(str,sqlconnection);//执行命令,读取数据sqldataadapter.Fill(dt);//填充表格this.dataGridView1.DataSource = dt;sqlconnection.Close();//关闭链接}</span></span>


 

 

 

 

二、EF实体框架

2.1,什么是?

实体框架(Entity Framework)是微软以ADO.Net为基础开发出来的对象关系映射(ORM)解决方案,它解决了对象持久化问题,将程序员从编写麻烦的SQL语句当中解放出来。 相对于传统的ADO等各种数据库操纵技术来说,微软的ADO.Net更为先进,它封装了很多底层操作,抽象了接口,针对接口编程,将调用统一化。

2.2,好处(个人理解)

我认为实体框架的好处是,当我们需要修改数据库或者实体时,能够通过实体模型的及时更新解决实体对应映射问题,而不用像之前一样一个一个的对照着修改。而且,它的跨数据库应用实践更为方便,只需要更改配置文件中的数据即可,可以直接将模型生成应用程序数据库到对应数据库服务中。

2.3,应用

2.3.1,准备工作

首先,实在VS中建立新项,添加新建项—数据—ADO.NET实体数据模型,然后设置其自己想要的映射的数据集,设置成功后,会生成一些列文件:

如上图所示,这就是我测试用的shoppingBus数据库生成的实体映射。其中有3个重要的类,分别是:

dataModel.Context.tt下的dataModel.Context.cs类,这个类是包含的数据库的上下文关系,我当时在看的时候就想到了设计模式策略模式中的context类,我认为它们有着共同之处,都是负责数据间的交互和实现。

DataModel.tt下的数据表类,比如这里的就是pet.cs类和petType.cs类。这里就是相当于具体的实体类,值得特别说明的是,EF生成的实体映射同时包括表关系,主外键的关系等。

2.3.2,实践

 

<span style="font-size:18px;"><span style="font-family:KaiTi_GB2312;font-size:24px;">  static void Main(string[] args){//第一步:创建EF访问数据库的统一入门,上下文:DbContextshoppingBusEntities1 dbcontext = new shoppingBusEntities1();#region 增、删、改//第二步:插入一条数据,添加一个宠物类型pet pet = new pet();pet.petID = "003";pet.petName = "人";pet.petPrice = 19;//第三步:修改数据,设置状态dbcontext.Entry<pet>(pet).State = EntityState.Modified;//增、删、改,直接修改实体的状态即可#endregion#region 查询var temps = from p in dbcontext.petwhere p.petID == "001"select p;//查询全部列//select p.petName;//查询部分列 foreach (var myPet in temps){Console.WriteLine(myPet.petID + "  " + myPet.petName +" "+myPet.petPrice);}#endregion//第四步:命令把所有的变化都更新到数据库里面去dbcontext.SaveChanges();}</span></span>

 

 

说明:向原来用的SQL链接数据库操作数据一样,EF实体也有自己的逻辑步骤,则是:建立访问入口(上下文)—整理自己的数据—告诉上下文需要执行的操作—保存自己的操作。可以看到,尤其是在增、删、改的过程中,没有看见任何的SQL语句,但其实是由编译器先帮我们翻译成了SQL的脚本。所以,使用EF操作数据库和使用之前的方法操作数据库,主要的区别则是在转换脚本这一过程中的不同,EF需要转换,而之前的方法不需要。

 

三、总结

根据自己目前的理解,我觉得EF实体映射其实已经脱离了对数据库的一个操作。我们操作的应该是实体,然后通过实体映射给数据库。所以是进一步和数据库解耦和了,达到了一个真正的面向对象。

而使用EF实体还有好处就是,可以动态的更新实体和数据库的映射关系,从而就不用向原来一样费神费力的去两边对照修改。可以由数据库端更新,然后直接更新实体映射,也可以是更改实体映射,然后更新数据库。由于EF实体操作并不直接操作数据库,所以它在跨数据库操作方面(更改配置文件中的provider的提供方式),也有着自己的优势。

这篇关于【EF 1】EF实体框架 原理+实例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1106803

相关文章

Spring Boot Interceptor的原理、配置、顺序控制及与Filter的关键区别对比分析

《SpringBootInterceptor的原理、配置、顺序控制及与Filter的关键区别对比分析》本文主要介绍了SpringBoot中的拦截器(Interceptor)及其与过滤器(Filt... 目录前言一、核心功能二、拦截器的实现2.1 定义自定义拦截器2.2 注册拦截器三、多拦截器的执行顺序四、过

Go异常处理、泛型和文件操作实例代码

《Go异常处理、泛型和文件操作实例代码》Go语言的异常处理机制与传统的面向对象语言(如Java、C#)所使用的try-catch结构有所不同,它采用了自己独特的设计理念和方法,:本文主要介绍Go异... 目录一:异常处理常见的异常处理向上抛中断程序恢复程序二:泛型泛型函数泛型结构体泛型切片泛型 map三:文

Java 队列Queue从原理到实战指南

《Java队列Queue从原理到实战指南》本文介绍了Java中队列(Queue)的底层实现、常见方法及其区别,通过LinkedList和ArrayDeque的实现,以及循环队列的概念,展示了如何高效... 目录一、队列的认识队列的底层与集合框架常见的队列方法插入元素方法对比(add和offer)移除元素方法

SQL 注入攻击(SQL Injection)原理、利用方式与防御策略深度解析

《SQL注入攻击(SQLInjection)原理、利用方式与防御策略深度解析》本文将从SQL注入的基本原理、攻击方式、常见利用手法,到企业级防御方案进行全面讲解,以帮助开发者和安全人员更系统地理解... 目录一、前言二、SQL 注入攻击的基本概念三、SQL 注入常见类型分析1. 基于错误回显的注入(Erro

Spring IOC核心原理详解与运用实战教程

《SpringIOC核心原理详解与运用实战教程》本文详细解析了SpringIOC容器的核心原理,包括BeanFactory体系、依赖注入机制、循环依赖解决和三级缓存机制,同时,介绍了SpringBo... 目录1. Spring IOC核心原理深度解析1.1 BeanFactory体系与内部结构1.1.1

MySQL 批量插入的原理和实战方法(快速提升大数据导入效率)

《MySQL批量插入的原理和实战方法(快速提升大数据导入效率)》在日常开发中,我们经常需要将大量数据批量插入到MySQL数据库中,本文将介绍批量插入的原理、实现方法,并结合Python和PyMySQ... 目录一、批量插入的优势二、mysql 表的创建示例三、python 实现批量插入1. 安装 PyMyS

springboot+mybatis一对多查询+懒加载实例

《springboot+mybatis一对多查询+懒加载实例》文章介绍了如何在SpringBoot和MyBatis中实现一对多查询的懒加载,通过配置MyBatis的`fetchType`属性,可以全局... 目录springboot+myBATis一对多查询+懒加载parent相关代码child 相关代码懒

C++中的解释器模式实例详解

《C++中的解释器模式实例详解》这篇文章总结了C++标准库中的算法分类,还介绍了sort和stable_sort的区别,以及remove和erase的结合使用,结合实例代码给大家介绍的非常详细,感兴趣... 目录1、非修改序列算法1.1 find 和 find_if1.2 count 和 count_if1

MySQL中如何求平均值常见实例(AVG函数详解)

《MySQL中如何求平均值常见实例(AVG函数详解)》MySQLavg()是一个聚合函数,用于返回各种记录中表达式的平均值,:本文主要介绍MySQL中用AVG函数如何求平均值的相关资料,文中通过代... 目录前言一、基本语法二、示例讲解1. 计算全表平均分2. 计算某门课程的平均分(例如:Math)三、结合

深入理解Redis线程模型的原理及使用

《深入理解Redis线程模型的原理及使用》Redis的线程模型整体还是多线程的,只是后台执行指令的核心线程是单线程的,整个线程模型可以理解为还是以单线程为主,基于这种单线程为主的线程模型,不同客户端的... 目录1 Redis是单线程www.chinasem.cn还是多线程2 Redis如何保证指令原子性2.