EF原理

EF原理EF原理

大家好,又见面了,我是你们的朋友全栈君。

EF简介

    实体框架(Entity Framework)简称EF,是微软以ADO.NET为基础所发展出来的对象关系对应(O/R Mapping)解决方案。是ADO.NET中的一组支持开发面向数据的软件应用程序的技术。是微软的一个ORM框架。

ORM

    O/R Mapping 是EF中非常重要的一个思想,官方解释为:ORM指的是面向对象的对象模型和关系型数据库的结构之间的相互转换。

    通俗的讲,ORM就是将表实体的变化映射到一个表。

EF原理

    通过ORM思想的指导,Entity Framework就可以帮助开发人员跟踪实体的变化,将实体的变化翻译成SQL脚本,并执行到数据中去,也就是将实体的变化映射到了表的变化。

EF原理

    上图也很好的解释了EF的工作原理,我们所做的增删改查操作通过ObjectContext上下文传到ORM,通过实体的变化映射到关系表,从而实现对数据库的操作。

    那么在EF中是如何实现对数据的增删改查呢?我们可以根据自己的情况选择不同的实现方式,主要有DbFirst,ModelFirst,CodeFirst几种方式:

 1.Database First是基于已存在的数据库,利用某些工具(如VS提供的EF设计器)创建实体类,数据库对象与实体类的匹配关系等,你也可以手动修改这些自动生成的代码及匹配文件。也就是从一个数据库开始,然后生成实体框架和相应代码。
 2.Model First 是先利用某些工具(如VS的EF设计器)设计出可视化的实体数据模型及他们之间的关系,然后再根据这些实体、关系去生成数据库对象及相关代码文件。
 3.Code First 这种方式需要先写一些代码,如实体对象,数据关系等,然后根据已有的代码描述,自动创建数据对象。但其实这种方法与Model First是非常类似的。我们自己写的代码,其实就是用代码表示实体模型,而Model First是用可视化的方式描述了实体模型。

    我们仅仅是在理论上了解了EntityFramework,它的强大之处还需要具体的实例来体验。个人认为DbFirst是比较常用的方式,下一篇将具体介绍如何实现。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/105739.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • snmp的trap_web scraping

    snmp的trap_web scrapingSNMP(SimpleNetworkManagementProtocol)trap是一种很有用,但是也容易让人难以理解的协议。虽然名字叫做简单网络管理协议,但实际上并不是字面上的意思,尤其是看到.1.3.6.1.2.1.1.1.0这样一串串诡异的数字时候,就会有点让人崩溃。不管怎么说,现在所有的网络设备的都需要支持SNMP。而且现在还有很多的开源的网络管理系统,所以就有利于我们来学习和

    2022年8月20日
    6
  • 软件测试技术之: 白盒测试和黑盒测试[通俗易懂]

    软件测试技术之: 白盒测试和黑盒测试[通俗易懂]白盒测试和黑盒测试的区别和基本方法。

    2022年9月18日
    0
  • java中int和char转换_java 二维数组

    java中int和char转换_java 二维数组在java中int与char之间的互相转化引言数据类型在介绍int与char的转换之前,我们先来回顾一下java中的基本数据类型:|类型|大小|包装器类型||boolean|-|Boolean||char|16-bit|Character||byte|8bits|Byte||short|16bits|Short|…

    2022年4月19日
    96
  • oracle与mysql的区别面试题_oracle和db2的主要区别

    oracle与mysql的区别面试题_oracle和db2的主要区别Oracle与Mysql区别Oracle是大型数据库而Mysql是中小型数据库,Oracle市场占有率达40%,Mysql只有20%左右,同时Mysql是开源的而Oracle价格非常高。Oracle支持大并发,大访问量,是OLTP最好的工具。安装所用的空间差别也是很大的,Mysql安装完后才152M而Oracle有3G左右,且使用的时候Oracle占用特别大的内存空间和其他机器性能。Oracle也Mysql操作上的一些区别①主键Mysql一般使用自动增长类型,在创建表时只要指定表的主键为

    2022年9月14日
    0
  • PCI PCI-X PCI-E区别「建议收藏」

    PCI PCI-X PCI-E区别「建议收藏」PCIPCI-XPCI-E区别

    2022年5月30日
    40
  • IIS防盗链:ISAPI Rewrite图片防盗链规则写法

    IIS防盗链:ISAPI Rewrite图片防盗链规则写法以下ISAPIRewrite已经在我的服务器上正常运作。经测试四种情况正常,即站内链接正常,白名单里的链接正常,盗链者链接屏蔽,搜索引擎链接正常。详细如下;一、完全屏蔽所有盗链来源的写法(如已有其它规则,则置于已有规则的上面)代码:RewriteCondHost:(.+)RewriteCondReferer:(?!http://\1.*

    2022年7月23日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号