现如今

对象关系映射(ORM)框架

被大量的使用于企业级应用的开发

为什么要使用ORM?

ADO.NET操作数据库不好吗?

我们可以仔细想想

当我们使用ADO.NET操作数据库的时候

我们需要先获取连接字符串

接着根据连接字符串创建一个SqlConnection对象来打开与数据库的连接

紧接着还要创建SqlCommand对象来执行数据库命令

根据不同的命令还要创建相应的不同的对象来进行操作

比如SqlDataAdapter和DataSet等

另外这次操作完成之后

还要注意关闭数据库的连接通道,释放资源等问题

或许当我们操作ADO.NET习惯了之后并不觉得哪里麻烦

但是相信使用过ORM的同学在真正开发的时候很少在直接用ADO.NET来操作数据库了

真的真的有这么好用嘛?

骗你又没糖吃

举一个很简单的例子(可能不是很恰当,将就着吧...)

比如现在你想吃一道菜

需要经过自己去准备食材,点火拿锅炒菜等一系列的动作

但是现在给你提供了一个大厨

不不,大厨不好

给你一个可爱温柔,厨艺又好的漂亮老婆

这个可以有吧?

只要告诉老婆你想吃什么菜

漂亮老婆就会帮你做出来

而不需要你去经历做菜的过程

在这期间你还可以去做其他的事情(在此可自由发挥想象力...)

同样是吃到想吃的菜

你是选择费些精力自己去做

还是让老婆做?

这不是废话嘛!

而且老婆做的菜肯定比你自己做的好吃!

人家是有练过的!

ORM框架就相当于是你的老婆

...

同样是如此,ORM老婆操作数据库的性能和效率往往是比自己写的数据库操作要好

这就是ORM老婆框架所做的事情

她将数据库中的表和程序中的类用一种映射关系关联起来

做到了对数据库层的屏蔽

在之前,程序员需要耗费大量的时间、精力去编写具体的数据库访问的SQL语句

还要十分小心其中大量重复的代码是否有疏漏,并不能集中精力于业务逻辑开发

但是老婆的出现帮助程序员解决了这些问题

留给程序员的不在是繁琐的数据库操作

而且他们相当熟悉的类和对象

这从一方面大大降低了代码量,也使程序员更加专注于业务逻辑的实现

正如我们所知

数据库表与表之间的关系有可能十分复杂

1对1、1对多、多对1、多对多、级联等

在操作数据库时,程序员必须小心谨慎的注意这些关系

而这往往是十分痛苦的过程

ORM框架通过程序中的类和数据库中的表

建立起了一种关系映射

程序员通过操作熟悉的类和对象即可实现对数据库的操作

ORM框架会自动帮我们维护这些复杂的关系

这就做到了对数据库层的屏蔽

使得程序员可以方便,快捷的进行数据库操作

至于之前说到的性能问题

这就不得不讲到ORM框架一个十分重要和牛逼的技术

延迟加载

ORM框架将根据具体数据库操作需要,会自动延迟向后台数据库发送SQL请求

从而大大降低与数据库的交互次数,提高数据库吞吐率提高运行效率

此外

ORM也可以根据实际情况,将数据库访问操作合成,尽量减少不必要的数据库操作请求

这个老婆是不是很贴心?

方方面面都给你想到了你还不要?

不管你要不要反正我是要了

用她又不用钱!是吧

接下来介绍一下EF

Entity Framework是微软以 ADO.NET 为基础所发展出来的对象关系对应解决方案

ORM框架的中的一种

(众多老婆中的一个)

在早期

人们在.NET平台下经常使用的ORM框架是NHibernate

这是一个Java平台的Hibernate移植过来的ORM框架

其强大的功能和性能深受程序员的喜爱

这可是正房夫人呀

早早的就虏获了众多程序员的心

但是现在人们的中心已经渐渐的转移到了二房

没错

就是EF

注意,她不是小三...

原因很简单

看过狗血电视剧的同学应该都知道

二房一般都是比正房夫人漂亮的!

不然人家大地主为毛要娶那么多个

不就是因为一个比一个漂亮

一个比一个好用嘛!(这里好像有点用词不当...)

EF就是一个比NHibernate漂亮,好用的老婆

因为她能和.NET平台完美的结合

而且提供可视化的关系对象映射模型

前面提到过

ORM框架根据程序的类和对象与数据库的表建立起了一种映射关系

这个映射关系通过xml文档保存在程序内部(比如配置文件)

在NHibernate中

程序员需要编写很繁杂的xml代码来实现这种映射关系

而这个过程同样也是十分痛苦的

常常因为一点点小的配置问题导致无法访问数据库

这就是正房夫人的不对了吧

你让本大人受罪

再娶一个气死你

而在EF中

提供了一种edmx文件

它本质上还是一个xml文档

但是它可以为程序员提供一个可视化的界面图形

人们可以通过简单的鼠标或者键盘操作来完成关系的映射

看吧,是不是比那个当正房的漂亮又好用多了

ORM和EF的简单介绍到此为止

与此同时本菜鸟的MVC之旅也拉开序幕

欲知后事如何,且听下回分解

转载于:https://www.cnblogs.com/jchubby/p/4429723.html

ASP.NET MVC学习---(一)ORM框架,EF实体数据模型简介相关推荐

  1. (转)ASP.NET MVC 学习第一天

    天道酬勤0322 博客园 | 首页 | 发新随笔 | 发新文章 | 联系 | 订阅  | 管理 随笔:10 文章:0 评论:9 引用:0 ASP.NET MVC 学习第一天 今天开始第一天学习asp. ...

  2. ASP.NET MVC学习之路由篇(2)

    ASP.NET MVC学习之路由篇(2) 原文:ASP.NET MVC学习之路由篇(2) 继ASP.NET MVC学习之路由篇(1)后继续学习. 7.解决与物理路径的冲突 当发送一个请求至ASP.NE ...

  3. ASP.NET MVC学习资料 新增几个开源项目

    ASP.NET MVC学习资料 新增几个开源项目 ASP.NET MVC MSDN API:  System.Web.Mvc Namespace (暂无中文版):  http://msdn.micro ...

  4. ASP.NET MVC学习之控制器篇

    一.前言 许久之后终于可以继续我的ASP.NET MVC连载了,之前我们全面的讲述了路由相关的知识,下面我们将开始控制器和动作的讲解. ASP.NET MVC学习之路由篇幅(1) ASP.NET MV ...

  5. 微软ORM框架EF初探

    微软ORM框架EF初探 一.ORM 顾名思义,ORM(ObjectRelational Mapping)对象关系映射,广义上是指面对对象的对象模型和关系型数据库的数据结构之间的相互装换.通俗来讲,就是 ...

  6. 【nodejs】让nodejs像后端mvc框架(asp.net mvc)一orm篇【如EF般丝滑】typeorm介绍(8/8)...

    文章目录 前情概要 在使用nodejs开发过程中,刚好碰到需要做一个小工具,需要用到数据库存储功能.而我又比较懒,一个小功能不想搞一个nodejs项目,又搞一个后端项目.不如直接在nodejs里面把对 ...

  7. 【ASP.NET MVC 学习笔记】- 07 使用 Entity Framework

    本文参考:http://www.cnblogs.com/willick/p/3304534.html 1.ORM(Object Relation Mapping)工具,是为了解决"关系数据库 ...

  8. ORM 框架--EF详解

    文章目录 EF ORM EF的三种创建方法 实体配置 配置 DataAnnotations FluentAPI 基本增删改查 增加 删除. 修改 查 原理及SQL监控 执行原生SQL. 不是所有lam ...

  9. asp.net mvc 学习

    Routing讲解: http://www.cnblogs.com/wangiqngpei557/p/3379095.html Filter讲解: http://www.cnblogs.com/ymn ...

最新文章

  1. 好用到爆的 Java 技巧
  2. 第一篇: 词向量之Word2vector原理浅析
  3. boost::spirit模块实现使用不同的输出语法格式化单个容器类型的测试程序
  4. html(5)标签form表单——进阶
  5. webServer tomcat5/tomcat6/tomcat7诠释
  6. 设计撑百万并发的数据库架构
  7. Linux中的Ramdisk和Initrd
  8. php 主进程子进程,PHP中的子进程的任何等价物?
  9. SVN和Maven及Jenkins(转)
  10. python办公自动化案例-用python进行办公自动化都需要学习什么知识呢?
  11. 防止第二代身份证泄露隐私
  12. GJB1188A校验C语言算法
  13. JS中使数组倒序排列
  14. 每个计算机主机只有一个硬盘吗,电脑多加一个硬盘需要重装系统吗? 电脑如何新增加一块硬盘...
  15. IOS 5 拦截手机短信(需越狱)
  16. java dao 是什么_dao java是什么
  17. 网易实习面经中的算法题(java版本含注释)
  18. ACO蚁群算法(附MATLAB源码)
  19. Annotation 介绍
  20. 如何下载win10原装镜像

热门文章

  1. mysql5.6找不到int_为什么在mysql 5.6中,在int字段上自动递增跳过“2147483646”?
  2. http://blog.51cto.com/yfsoft/324291
  3. Jumpserver0.4.0基于Centos7安装
  4. 网站中被误解的用户体验设计
  5. 持续交付模型中文化转型的重要意义
  6. jquery相对定位(包含find的使用 find相当于后代选择器)$(选择器1,选择器2)
  7. Windows Vista SP1正式版独立安装包
  8. mysql can't open file: '..frm'_mysqldump 导出数据时出现can’t opne file ‘xx.frm’ (errno:24)错误...
  9. ok计数器使用教程_Qt ModelView教程(二)——应用举例
  10. pythonshell窗口是什么_python与shell的3种交互方式介绍