当前位置: 首页 > news >正文

对象关系映射---ORM

一、什么是ORM?

ORM(Object Relational Mapping),即对象关系映射,是一种程序设计技术,用于在面向对象编程语言中实现对象和关系型数据库之间的映射。

二、ORM是干什么的?

ORM 的主要目的简化数据库操作,使得开发人员可以以面向对象的方式来处理数据库中的数据,而不必直接编写复杂的 SQL 语句。

三、ORM的优缺点

1.优点

(1)提高开发效率:开发人员可以专注于业务逻辑的实现,而不必花费大量时间在编写和优化 SQL 语句上。

例如,在创建、读取、更新和删除数据时,只需要操作对象,ORM 框架会自动将这些操作转换为相应的 SQL 语句。

(2)减少代码重复:ORM 框架通常提供了一套统一的接口和方法,使得在不同的项目中处理数据库操作的方式保持一致。

比如,无论使用哪种数据库,都可以使用类似的方法来进行数据的插入和查询。

(3)增强代码的可维护性:对象模型更贴近业务领域,使得代码更易于理解和维护。

当业务逻辑发生变化时,只需要修改对象的属性和方法,而不必修改底层的 SQL 语句。

2.缺点

(1)性能问题:在某些复杂的查询场景下,ORM 生成的 SQL 可能不如手动编写的高效。

例如,对于涉及大量关联和复杂条件的查询,可能需要手动优化 SQL 来提高性能。

(2)灵活性受限:某些特定的数据库特性或复杂的数据库操作可能难以通过 ORM 框架直接实现。

四、为什么要有ORM模型?

之所以要有 ORM 模型,主要基于以下几个重要原因:

1.提高开发效率

        开发人员无需花费大量时间和精力去编写复杂的 SQL 语句,专注于业务逻辑的实现。

        比如,在开发一个电商系统时,处理订单和商品的关联,使用 ORM 可以直接操作对象,而不用去考虑复杂的多表连接和数据查询语句。

2.降低数据库操作的复杂性

       关系型数据库的操作涉及诸多细节,如数据类型转换、索引优化等,ORM 框架进行了封装和处理。

        例如,不同数据库对于日期类型的处理可能略有不同,ORM 会在后台自动处理这些差异。

3.增强代码的可维护性和可读性

        以面向对象的方式处理数据,代码更贴近业务概念,易于理解和维护。

        假设要修改用户信息的逻辑,通过对象的方法和属性进行操作,代码结构更清晰,易于定位和修改。

4.跨数据库平台的兼容性

        当需要切换数据库时,只需修改少量的配置,而无需大量修改业务代码。

        比如,从 MySQL 迁移到 PostgreSQL,ORM 框架能够自动适配不同数据库的特性和语法差异。

5.减少代码错误

        ORM 框架通常会进行一些输入验证和错误处理,降低因手动编写 SQL 导致的错误。

        例如,防止 SQL 注入攻击,确保数据的安全性。

6.便于团队协作

        统一的对象操作方式,使得团队成员之间更容易理解和交流代码。

        在一个多人开发的项目中,大家都遵循相同的 ORM 规范进行数据库操作,减少了沟通成本和代码冲突的可能性。

综上所述,ORM 模型的出现极大地改善了软件开发过程中与数据库交互的效率、质量和可维护性。

五、ORM映射哪些内容?(重要)

ORM 要映射的内容主要包括以下几个方面:

1.类和表的映射

         在 Java 中定义的类会对应到关系型数据库中的表。例如,定义一个名为 User 的类,它可能会映射到数据库中的 user 表。

2.字段和属性的映射

        类中的属性会对应到表中的字段。比如,User 类中的 idnameage 等属性,会分别映射到 user 表中的 idnameage 字段。

3.Java 数据类型和数据库中的数据类型

        Java 中的基本数据类型(如 intStringdouble 等)以及引用数据类型(如自定义的类)需要与数据库中的相应数据类型(如 INTVARCHARDOUBLE 等)进行映射。

        例如,Java 中的 int 类型通常会映射到数据库中的 INT 类型,String 类型可能映射到 VARCHAR 或 TEXT 类型。

4.对象关系的映射

        处理对象之间的关联关系,如一对一、一对多、多对多等。

        比如,一个 Order 类与 OrderItem 类可能存在一对多的关系,在数据库中通过外键来实现这种关联,ORM 框架会负责处理这种关系的映射和数据的同步。

5.继承关系的映射

        如果在 Java 中存在类的继承关系,ORM 框架需要确定如何将这种继承关系映射到数据库中。

        常见的策略有单表继承、每个具体类一张表、类层次表等。

6.对象的生命周期管理

        包括对象的创建、读取、更新和删除操作与数据库中的插入、查询、修改和删除操作的映射。

        通过这些映射,ORM 框架使得开发人员能够以面向对象的方式来操作数据库,而无需直接处理底层的 SQL 语句和数据库细节。

六、常见的ORM框架有什么?

        常见的 ORM 框架有 Hibernate(Java 领域)、Entity Framework(.NET 领域)、Django ORM(Python 的 Django 框架)等。

        总之,ORM 是一种在软件开发中非常有用的技术,但在使用时需要根据项目的具体需求和性能要求来权衡其优缺点。

七、ORM 框架是如何实现对象和关系型数据库之间的映射的?

ORM 框架实现对象和关系型数据库之间映射的过程通常包含以下几个关键步骤:

1.对象模型定义

        开发人员使用编程语言定义对象类,这些类的属性对应着数据库表中的列。

        例如,在 Java 中使用类来表示实体,如 class User { private int id; private String name; } ,其中 id 和 name 分别对应数据库中 user 表的列。

2.映射配置

        通过配置文件或注解来指定对象与数据库表、对象属性与表列之间的映射关系。

        以 Hibernate 框架为例,可以使用 @Entity 注解标记实体类,使用 @Column 注解指定属性与列的映射细节。

3.数据持久化

        当创建对象并设置其属性值后,ORM 框架会将对象的状态转换为相应的 SQL 语句来执行数据库操作。

        比如,插入一个新的用户对象时,ORM 框架会生成类似 INSERT INTO user (id, name) VALUES (?,?) 的 SQL 语句,并填充实际的值。

4.数据检索

        执行数据库查询操作时,ORM 框架将查询结果转换为对应的对象。

        例如,查询 user 表获取用户数据,ORM 框架会把每一行数据映射为一个 User 对象,并填充对象的属性值。

5.关系映射

        处理对象之间的关联关系,如一对一、一对多、多对多等。

        例如,一个 Order 对象与多个 OrderItem 对象存在一对多关系,ORM 框架在查询 Order 对象时,会自动关联获取相关的 OrderItem 对象。

7.缓存管理

        为了提高性能,ORM 框架通常会实现一定的缓存机制,减少对数据库的重复查询。

        比如,将经常访问的数据缓存到内存中,下次请求相同数据时直接从缓存中获取。

8.事务处理

        确保数据库操作的原子性、一致性、隔离性和持久性(ACID)。

        例如,在一个业务流程中,涉及多个数据库操作,ORM 框架会将这些操作包装在一个事务中,要么全部成功,要么全部失败回滚。

        总之,ORM 框架通过上述一系列机制,实现了对象和关系型数据库之间的无缝映射,使得开发人员能够更便捷地进行数据库操作,而无需过多关注底层的数据库细节。

一、Mybatis和hibernate 区别(面试)

1. Hibernate是全自动化ORM; Mybatis是半自动化ORM。

2. Hibernate简化dao层,不用考虑SQL语句的编写和结果映射,重点放在业务逻辑上;     Mybatis需要手写SQL语句以及结果映射。

3. Hibernate是一个重量级的框架,内部生成SQL语句,反射操作太多,导致性能下降;            Mybatis是一个轻量级的框架,需要自己写sql语句,有较少的反射操作。

4. Hibernate 不方便做SQL优化,遇到较复杂的SQL语句需要绕过框架实现复杂, 对多字段的结构进行部分映射困难;

        Mybatis 不仅可以做SQL优化还可以SQL与Java分离,还可以自行编写映射关系, 复杂的SQL语句Mybatis效率更高

Mybatis优势: 可以进行更细致的SQL优化;容易掌握

Hibernate优势:dao层开发比mybatis简单,mybatis需要维护SQL和结果映射

                            hibernate数据库移植性好

相关文章:

对象关系映射---ORM

一、什么是ORM? ORM(Object Relational Mapping),即对象关系映射,是一种程序设计技术,用于在面向对象编程语言中实现对象和关系型数据库之间的映射。 二、ORM是干什么的? ORM 的主要目的是简…...

Django REST Framework(十七)Authentication

1.认证Authentication 在 Django REST framework (DRF) 中,可以在配置文件中配置全局默认的认证方案。常见的认证方式包括 cookie、session、和 token。DRF 提供了灵活的认证机制,可以在全局配置文件中设置默认认证方式,也可以在具体的视图类…...

FPGA开发——数码管的使用

一、概述 在我们的日常开发中,数字显示的领域中用得最多的就是数码管,这篇文章也是围绕数码管的静态显示和动态显示进行一个讲解。 1、理论 (1)数码管原理图 在对数码管进行相关控制时,其实就是对于8段发光二极管和…...

什么是网络安全等级保护测评服务?

等保测评 依据国家网络安全等级保护制度规定,按照有关管理规范和技术标准,对非涉及国家秘密的网络安全等级保护状况进行检测评估。定级协助 根据等级保护对象在国家安全、经济建设、社会生活中的重要程度,以及一旦遭到破坏、丧失功能或者数据…...

基于深度学习的多模态情感分析

基于深度学习的多模态情感分析是一个结合不同类型数据(如文本、图像、音频等)来检测和分析情感的领域。它利用深度学习技术来处理和融合多模态信息,从而提高情感分析的准确性和鲁棒性。以下是对这一领域的详细介绍: 1. **多模态情…...

Glove-词向量

文章目录 共现矩阵共线概率共线概率比词向量训练总结词向量存在的问题 上一篇文章词的向量化介绍了词的向量化,词向量的训练方式可以基于语言模型、基于窗口的CBOW和SKipGram的这几种方法。今天介绍的Glove也是一种训练词向量的一种方法,他是基于共现概率…...

Plugin ‘mysql_native_password‘ is not loaded`

Plugin mysql_native_password is not loaded mysql_native_password介绍1. 使用默认的认证插件2. 修改 my.cnf 或 my.ini 配置文件3. 加载插件(如果确实没有加载)4. 重新安装或检查 MySQL 版本 遇到错误 ERROR 1524 (HY000): Plugin mysql_native_passw…...

Hive数据类型

原生数据类型 准备数据 查看表信息 加载数据 查看数据 复杂数据类型-数组 准备数据 查看数据 ​优化 复杂数据类型-map 准备数据 查看数据 复杂数据类型-默认分隔符 准备数据 查看数据 原生数据类型 准备数据 -- 1 建库 drop database if exists db_1 cascade;…...

OSI七层网络模型:构建网络通信的基石

在计算机网络领域,OSI(Open Systems Interconnection)七层模型是理解网络通信过程的关键框架。该模型将网络通信过程细分为七个层次,每一层都有其特定的功能和职责,共同协作完成数据从发送端到接收端的传输。接下来&am…...

MSYS2下载安装和使用

Minimalist GNU(POSIX)system on Windows,Windows下的GNU环境。 目录 1. 安装 2. pacman命令 3. 配置vim 4. 一些使用示例 4.1 编译代码 4.2 SSH登录远程服务器 1. 安装 官网下载:https://www.msys2.org/ 双击.exe文件&am…...

机器学习中的决策树算法——从理论到实践完整指南

决策树在机器学习中的应用与原理 1. 介绍1.1 定义和基本概念1.2 决策树在机器学习中的角色和重要性 2. 决策树的结构2.1 节点、分支、叶子节点的定义和功能2.1.1 节点2.1.2 分支2.1.3 叶子节点 2.2 树的深度和宽度的影响2.2.1 树的深度2.2.2 树的宽度 3. 决策树的构建方法3.1 基…...

FFplay介绍及命令使用指南

😎 作者介绍:欢迎来到我的主页👈,我是程序员行者孙,一个热爱分享技术的制能工人。计算机本硕,人工制能研究生。公众号:AI Sun(领取大厂面经等资料),欢迎加我的…...

php实现动态登录

简介: 效果:通过前端页面的注册,通过MD5将密码加密,发送到数据库,通过验证数据库的内容实现登录,以及各种保证安全的措施 实验环境:phphtmlcssmysql数据表,使用html css设计注册&a…...

Servlet2-HTTP协议、HttpServletRequest类、HttpServletResponse类

目录 HTTP协议 什么是HTTP协议 HTTP协议的特点 请求的HTTP协议格式 GET请求 POST请求 常用的请求头说明 哪些是GET请求,哪些是POST请求 响应的HTTP协议格式 常见的响应码说明 MIME类型说明 HttpServletRequest类 作用 常用方法 如何获取请求参数 po…...

探索数据的内在世界:sklearn中分层特征聚类标签的可视化技术

探索数据的内在世界:sklearn中分层特征聚类标签的可视化技术 在机器学习中,聚类是一种探索数据结构的强大工具。对于具有分层特征的数据,如文本、时间序列或分类标签,聚类结果的可视化可以提供深入的洞见。本文将详细介绍如何在s…...

airtest定位方法

airtest定位方法 最近遇到一个比较新颖的airtest方法,分享给大家。一键三连; airtest是一款用于自动化测试的Python库,被广泛应用于移动应用和游戏的测试中。在进行自动化测试时,定位元素是非常重要的一步,因为只有准…...

排列组合 n*(n-1)*(n-m+1)

n*(n-1)*(n-m1)/m! --# 组合 n*(n-1)*(n-m1)/m! local function get_combinations(n,m) c 1 c0 1 for i 1,m do c c*(n-i1) c c/i end return math.floor(c) end print(get_combinations(10,6)) 打印出来为:210...

Python面试整理-数据处理和分析

在Python中,数据处理和分析是一项非常重要的应用,得益于丰富的第三方库和工具,Python已经成为数据科学家和分析师的首选语言之一。以下是进行数据处理和分析时常用的工具和方法: 1. 数据处理 a. Pandas ● 功能: Pandas 提供了强大的 DataFrame 结构,使得数据操作和预处理…...

职业教育计算机网络综合实验实训室建设应用案例

近年来,职业教育在培养技能型人才方面发挥着越来越重要的作用。然而,传统的计算机网络技术教学模式往往重理论、轻实践,导致学生缺乏实际操作能力和职业竞争力。为了改变这一现状,唯众结合职业教育特点,提出了“教、学…...

【Docomo】5G

我们想向您介绍第五代移动通信系统“5G”。 5G 什么是5G?支持5G的技术什么是 5G SA(独立)?实现高速率、大容量的5G新频段Docomo的“瞬时5G”使用三个宽广的新频段 什么是5G? 5G(第五代移动通信系统&#x…...

shell脚本--常见案例

1、自动备份文件或目录 2、批量重命名文件 3、查找并删除指定名称的文件: 4、批量删除文件 5、查找并替换文件内容 6、批量创建文件 7、创建文件夹并移动文件 8、在文件夹中查找文件...

边缘计算医疗风险自查APP开发方案

核心目标:在便携设备(智能手表/家用检测仪)部署轻量化疾病预测模型,实现低延迟、隐私安全的实时健康风险评估。 一、技术架构设计 #mermaid-svg-iuNaeeLK2YoFKfao {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg…...

《Playwright:微软的自动化测试工具详解》

Playwright 简介:声明内容来自网络,将内容拼接整理出来的文档 Playwright 是微软开发的自动化测试工具,支持 Chrome、Firefox、Safari 等主流浏览器,提供多语言 API(Python、JavaScript、Java、.NET)。它的特点包括&a…...

visual studio 2022更改主题为深色

visual studio 2022更改主题为深色 点击visual studio 上方的 工具-> 选项 在选项窗口中,选择 环境 -> 常规 ,将其中的颜色主题改成深色 点击确定,更改完成...

UDP(Echoserver)

网络命令 Ping 命令 检测网络是否连通 使用方法: ping -c 次数 网址ping -c 3 www.baidu.comnetstat 命令 netstat 是一个用来查看网络状态的重要工具. 语法:netstat [选项] 功能:查看网络状态 常用选项: n 拒绝显示别名&#…...

学校招生小程序源码介绍

基于ThinkPHPFastAdminUniApp开发的学校招生小程序源码,专为学校招生场景量身打造,功能实用且操作便捷。 从技术架构来看,ThinkPHP提供稳定可靠的后台服务,FastAdmin加速开发流程,UniApp则保障小程序在多端有良好的兼…...

P3 QT项目----记事本(3.8)

3.8 记事本项目总结 项目源码 1.main.cpp #include "widget.h" #include <QApplication> int main(int argc, char *argv[]) {QApplication a(argc, argv);Widget w;w.show();return a.exec(); } 2.widget.cpp #include "widget.h" #include &q…...

DIY|Mac 搭建 ESP-IDF 开发环境及编译小智 AI

前一阵子在百度 AI 开发者大会上&#xff0c;看到基于小智 AI DIY 玩具的演示&#xff0c;感觉有点意思&#xff0c;想着自己也来试试。 如果只是想烧录现成的固件&#xff0c;乐鑫官方除了提供了 Windows 版本的 Flash 下载工具 之外&#xff0c;还提供了基于网页版的 ESP LA…...

DeepSeek 技术赋能无人农场协同作业:用 AI 重构农田管理 “神经网”

目录 一、引言二、DeepSeek 技术大揭秘2.1 核心架构解析2.2 关键技术剖析 三、智能农业无人农场协同作业现状3.1 发展现状概述3.2 协同作业模式介绍 四、DeepSeek 的 “农场奇妙游”4.1 数据处理与分析4.2 作物生长监测与预测4.3 病虫害防治4.4 农机协同作业调度 五、实际案例大…...

AI,如何重构理解、匹配与决策?

AI 时代&#xff0c;我们如何理解消费&#xff1f; 作者&#xff5c;王彬 封面&#xff5c;Unplash 人们通过信息理解世界。 曾几何时&#xff0c;PC 与移动互联网重塑了人们的购物路径&#xff1a;信息变得唾手可得&#xff0c;商品决策变得高度依赖内容。 但 AI 时代的来…...