什么是ORM

ORM(Object-relational mapping),中文翻译为对象关系映射,是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术。简单的说,ORM是通过使用描述对象和数据库之间映射的元数据,将程序中的对象自动持久化到关系数据库中

为什么用ORM

在程序开发中,数据库保存的表,字段与程序中的实体类之间是没有关联的,在实现持久化时就比较不方便。那么,到底如何实现持久化呢?一种简单的方案是采用硬编码方式,为每一种可能的数据库访问操作提供单独的方法。这种方案存在以下不足:

  • 1.持久化层缺乏弹性。一旦出现业务需求的变更,就必须修改持久化层的接口
  • 2.持久化层同时与域模型与关系数据库模型绑定,不管域模型还是关系数据库模型发生变化,毒药修改持久化曾的相关程序代码,增加了软件的维护难度

ORM提供了实现持久化层的另一种模式,它采用映射元数据来描述对象关系的映射,使得ORM中间件能在任何一个应用的业务逻辑层和数据库层之间充当桥梁

ORM的方法论基于三个核心原则:

  • 简单:以最基本的形式建模数据
  • 传达性:数据库结构被任何人都能理解的语言文档化
  • 精确性:基于数据模型创建正确标准化了的结构

本文以C#编程语言为例,在传统的数据读取操作中,我们以Ado.net的方式对数据库进行CRUD操作,使用的基本都是SQL硬编码,比如有以下数据库查询操作:

 
  1. String sql = "SELECT ... FROM persons WHERE id = 10";

  2. DbCommand cmd = new DbCommand(connection, sql);

  3. Result res = cmd.Execute();

  4. String name = res[0]["FIRST_NAME"];

使用了ORM映射的C#实现的伪代码:

 
  1. Person p = repository.GetPerson(10);

  2. String name = p.getFirstName();

上面的示例代码表示我们可以从数据仓库repository中获取到一个实体对象,当然数据仓库中可能包含其他的方法,你也可以定义自己的ORM实现,比如:

Person p = Person.Get(10);

通常,在处理ORM映射和数据仓库时会暴露一些过滤或者查询方法,允许客户端对数据集进行进一步的筛选等操作,比如代码演示从数据库中查询ID=10的用户:

Person p = Person.Get(Person.Properties.Id == 10);

优/缺点

优点

与传统的数据库访问技术相比,ORM有以下优点:

  • 开发效率更高
  • 数据访问更抽象、轻便
  • 支持面向对象封装

缺点

  • 降低程序的执行效率
  • 思维固定化

从系统结构上来看,采用ORM的系统一般都是多层系统,系统的层次多了,效率就会降低。ORM是一种完全的面向对象的做法,而面向对象的做法也会对性能产生一定的影响。

在我们开发系统时,一般都有性能问题。性能问题主要产生在算法不正确和与数据库不正确的使用上。ORM所生成的代码一般不太可能写出很高效的算法,在数据库应用上更有可能会被误用,主要体现在对持久对象的提取和和数据的加工处理上,如果用上了ORM,程序员很有可能将全部的数据提取到内存对象中,然后再进行过滤和加工处理,这样就容易产生性能问题。

总结

作为一名编程人员,在ORM使用的观念上会有不同,具体取舍需根据具体的项目和场景。

本文同步发表至 码友网 《什么是ORM?为什么用ORM?浅析ORM的使用及利弊》

================================================================================================

  • 什么是“持久化”

持久(Persistence),即把数据(如内存中的对象)保存到可永久保存的存储设备中(如磁盘)。持久化的主要应用是将内存中的数据存储在关系型的数据库中,当然也可以存储在磁盘文件中、XML数据文件中等等。

  • 什么是“持久层”

持久层(Persistence Layer),即专注于实现数据持久化应用领域的某个特定系统的一个逻辑层面,将数据使用者和数据实体相关联。

  • 什么是ORM

即Object-Relationl Mapping,它的作用是在关系型数据库和对象之间作一个映射,这样,我们在具体的操作数据库的时候,就不需要再去和复杂的SQL语句打交道,只要像平时操作对象一样操作它就可以了 。

  • 为什么要做持久化和ORM设计(重要)

在目前的企业应用系统设计中,MVC,即 Model(模型)- View(视图)- Control(控制)为主要的系统架构模式。MVC 中的 Model 包含了复杂的业务逻辑和数据逻辑,以及数据存取机制(如 JDBC的连接、SQL生成和Statement创建、还有ResultSet结果集的读取等)等。将这些复杂的业务逻辑和数据逻辑分离,以将系统的紧耦合关系转化为松耦合关系(即解耦合),是降低系统耦合度迫切要做的,也是持久化要做的工作。MVC 模式实现了架构上将表现层(即View)和数据处理层(即Model)分离的解耦合,而持久化的设计则实现了数据处理层内部的业务逻辑和数据逻辑分离的解耦合。而 ORM 作为持久化设计中的最重要也最复杂的技术,也是目前业界热点技术。

简单来说,按通常的系统设计,使用 JDBC 操作数据库,业务处理逻辑和数据存取逻辑是混杂在一起的。
一般基本都是如下几个步骤:
1、建立数据库连接,获得 Connection 对象。
2、根据用户的输入组装查询 SQL 语句。
3、根据 SQL 语句建立 Statement 对象 或者 PreparedStatement 对象。
4、用 Connection 对象执行 SQL语句,获得结果集 ResultSet 对象。
5、然后一条一条读取结果集 ResultSet 对象中的数据。
6、根据读取到的数据,按特定的业务逻辑进行计算。
7、根据计算得到的结果再组装更新 SQL 语句。
8、再使用 Connection 对象执行更新 SQL 语句,以更新数据库中的数据。
7、最后依次关闭各个 Statement 对象和 Connection 对象。

由上可看出代码逻辑非常复杂,这还不包括某条语句执行失败的处理逻辑。其中的业务处理逻辑和数据存取逻辑完全混杂在一块。而一个完整的系统要包含成千上万个这样重复的而又混杂的处理过程,假如要对其中某些业务逻辑或者一些相关联的业务流程做修改,要改动的代码量将不可想象。另一方面,假如要换数据库产品或者运行环境也可能是个不可能完成的任务。而用户的运行环境和要求却千差万别,我们不可能为每一个用户每一种运行环境设计一套一样的系统。
所以就要将一样的处理代码即业务逻辑和可能不一样的处理即数据存取逻辑分离开来,另一方面,关系型数据库中的数据基本都是以一行行的数据进行存取的,而程序运行却是一个个对象进行处理,而目前大部分数据库驱动技术(如ADO.NET、JDBC、ODBC等等)均是以行集的结果集一条条进行处理的。所以为解决这一困难,就出现 ORM 这一个对象和数据之间映射技术。

举例来说,比如要完成一个购物打折促销的程序,用 ORM 思想将如下实现(引自《深入浅出Hibernate》):
业务逻辑如下:
public Double calcAmount(String customerid, double amount) 
{
    // 根据客户ID获得客户记录
    Customer customer = CustomerManager.getCustomer(custmerid); 
    // 根据客户等级获得打折规则
    Promotion promotion = PromotionManager.getPromotion(customer.getLevel()); 
    // 累积客户总消费额,并保存累计结果
    customer.setSumAmount(customer.getSumAmount().add(amount); 
    CustomerManager.save(customer); 
    // 返回打折后的金额
    return amount.multiply(protomtion.getRatio()); 
}
这样代码就非常清晰了,而且与数据存取逻辑完全分离。设计业务逻辑代码的时候完全不需要考虑数据库JDBC的那些千篇一律的操作,而将它交给 CustomerManager 和 PromotionManager 两个类去完成。这就是一个简单的 ORM 设计,实际的 ORM 实现框架比这个要复杂的多。
————————————————
版权声明:本文为CSDN博主「zhangchibang311」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/zhangchibang311/article/details/83329802

ORM是什么,为什么用ORM相关推荐

  1. ORM框架简介和常用ORM框架

    目录 1.ORM简介 1.1什么是ORM 1.2.ORM技术的特点 3. 常用ORM框架 3.1.Hibernate 简介 优点 3.2.Mybatis 简介 功能结构 优点 1.ORM简介 1.1什 ...

  2. php的orm框架,PHP有什么ORM框架?

    对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术. ORM提供了实现持久化层的另一种模式,它采用映射元数据 ...

  3. mongodb orm java_基于Java的ORM框架 Mongodb-ORM

    软件介绍 mongodb-orm简介Mongodb ORM是基于java的ORM框架,简化了SDK的使用,使代码变得更清晰.简单. 与Ibatis类似,将查询.执行语句封装在xml中,与代码隔离.简称 ...

  4. java mysql orm框架_主流 Java ORM 框架有哪些?

    主流 Java ORM 框架有哪些? ORM 是 Object Relational Mapping 的缩写,译为 "对象关系映射" 框架. 所谓的 ORM 框架就是一种为了解决面 ...

  5. 充血模型的ORM能做什么?——ORM组件XCode(十八般武艺)

    ORM组件XCode(十八般武艺)<?xml:namespace prefix = o /> 之前,XCode总是若隐若现,耐性好的同学想知道它还有啥特点,沉不住气的则认为不过是CURD耳 ...

  6. mysql orm .net,2020年 .NET ORM 完整比较、助力选择

    原标题:2020年 .NET ORM 完整比较.助力选择 转自:nicye cnblogs.com/kellynic/p/13664720.html 一.前言 为什么要写这篇文章? 希望针对 SEO ...

  7. ORM(手写简单ORM)

    ORM(Object Relation Mapping,对象关系映射) 表结构<–>类 表中字段 <–>类的属性 表中记录<–>对象 简单完成从数据库到对象的映射 ...

  8. flask orm 数据库_Flask:使用ORM框架操作数据库

    在Flask中并没有限制我们使用哪种方式来操作数据库,如果使用原生SQL的方式来操作数据库,随着项目代码量的提升会发现有大量操作数据库的冗余代码,以及大量SQL语句与逻辑代码杂糅在一起不利于核心代码的 ...

  9. php orm 内存泄漏,Lavarel Eloquent ORM常驻进程下的内存溢出问题

    Laravel 的 Eloquent ORM 提供了漂亮.简洁的 ActiveRecord 实现来和数据库交互.每个数据库表都有一个对应的「模型」用来与该表交互.你可以通过模型查询数据表中的数据,并将 ...

  10. 【ORM框架】go语言ORM框架 - gorm快速入门

    文章目录 前言 一.正确看待orm 1.什么是orm 2.常用的orm 3.orm的优缺点 4.如何正确看待orm和sql之间的关系 二.gorm入门 前言 Gorm 是 Golang 的一个 orm ...

最新文章

  1. u盘属性显示制造商不可用问题的解决方法
  2. iMX6开发板-uboot-网络设置和测试
  3. android https详解,如何使用HTTPS和HTTP来解析Android中的JSON数据?
  4. 删除苹果自带软件后果_ghost explorer工具怎么删除ghost自带软件【详细教程】
  5. 《数据结构》二叉查找树
  6. oracle row number (),Oracle 分析函数 ROW_NUMBER() 使用
  7. 怎么在pta上搜题_在电脑上搜题,是不用模拟器的那种
  8. cs6给画笔分组_画笔工具,PS cs6笔刷入门介绍
  9. 如何查询linux服务器的网卡,linux怎么查看网卡硬件信息
  10. 华为无线路由器信道怎么测试软件,华为路由WS5200怎么修改wifi信道
  11. 台式win10系统你要来自Trustedinstaller的权限才能对此文件进行更改?
  12. CocosStudio(八)AtlasLabel数字标签、BitmapLabel自定义字体、Label文本框
  13. 赛尔号对战c语言程序,赛尔号计算解析系列文章(第一期)
  14. 企业邮箱怎么注册?企业邮箱注册流程是什么?
  15. python中------decode解码出现的0xca问题解决方法
  16. 差压传感器和差压变送器的区别在哪里
  17. 地震勘探基础(十三)之地震资料解释
  18. 如何建立自己的认知体系
  19. 基于C#的全国天气查询API调用代码实例
  20. 人工智能在医疗保健中的应用与创新

热门文章

  1. 网络设备解析:中继器、集线器、网桥、交换机、路由器、网关的区别
  2. Linux 下 Monit 监控
  3. Ubuntu 安装lua
  4. Python笔记【二】
  5. Mitov MegaLab VCL 和 FireMonkey
  6. 微信小程序引用Echarts绘图显示模糊解决办法
  7. html圆圈倒计时,用HTML5实现的圆形时钟倒计时
  8. 浅谈web前端三大主流框架
  9. webflux oracle,從MVC到WebFlux
  10. 通过demo学习OpenStack开发所需的基础知识 -- 单元测试