对象关系映射---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类中的id、name、age等属性,会分别映射到user表中的id、name、age字段。3.Java 数据类型和数据库中的数据类型:
Java 中的基本数据类型(如
int、String、double等)以及引用数据类型(如自定义的类)需要与数据库中的相应数据类型(如INT、VARCHAR、DOUBLE等)进行映射。例如,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…...
uniapp 对接腾讯云IM群组成员管理(增删改查)
UniApp 实战:腾讯云IM群组成员管理(增删改查) 一、前言 在社交类App开发中,群组成员管理是核心功能之一。本文将基于UniApp框架,结合腾讯云IM SDK,详细讲解如何实现群组成员的增删改查全流程。 权限校验…...
零门槛NAS搭建:WinNAS如何让普通电脑秒变私有云?
一、核心优势:专为Windows用户设计的极简NAS WinNAS由深圳耘想存储科技开发,是一款收费低廉但功能全面的Windows NAS工具,主打“无学习成本部署” 。与其他NAS软件相比,其优势在于: 无需硬件改造:将任意W…...
Golang 面试经典题:map 的 key 可以是什么类型?哪些不可以?
Golang 面试经典题:map 的 key 可以是什么类型?哪些不可以? 在 Golang 的面试中,map 类型的使用是一个常见的考点,其中对 key 类型的合法性 是一道常被提及的基础却很容易被忽视的问题。本文将带你深入理解 Golang 中…...
线程与协程
1. 线程与协程 1.1. “函数调用级别”的切换、上下文切换 1. 函数调用级别的切换 “函数调用级别的切换”是指:像函数调用/返回一样轻量地完成任务切换。 举例说明: 当你在程序中写一个函数调用: funcA() 然后 funcA 执行完后返回&…...
【网络安全产品大调研系列】2. 体验漏洞扫描
前言 2023 年漏洞扫描服务市场规模预计为 3.06(十亿美元)。漏洞扫描服务市场行业预计将从 2024 年的 3.48(十亿美元)增长到 2032 年的 9.54(十亿美元)。预测期内漏洞扫描服务市场 CAGR(增长率&…...
基于当前项目通过npm包形式暴露公共组件
1.package.sjon文件配置 其中xh-flowable就是暴露出去的npm包名 2.创建tpyes文件夹,并新增内容 3.创建package文件夹...
leetcodeSQL解题:3564. 季节性销售分析
leetcodeSQL解题:3564. 季节性销售分析 题目: 表:sales ---------------------- | Column Name | Type | ---------------------- | sale_id | int | | product_id | int | | sale_date | date | | quantity | int | | price | decimal | -…...
大语言模型(LLM)中的KV缓存压缩与动态稀疏注意力机制设计
随着大语言模型(LLM)参数规模的增长,推理阶段的内存占用和计算复杂度成为核心挑战。传统注意力机制的计算复杂度随序列长度呈二次方增长,而KV缓存的内存消耗可能高达数十GB(例如Llama2-7B处理100K token时需50GB内存&a…...
【学习笔记】erase 删除顺序迭代器后迭代器失效的解决方案
目录 使用 erase 返回值继续迭代使用索引进行遍历 我们知道类似 vector 的顺序迭代器被删除后,迭代器会失效,因为顺序迭代器在内存中是连续存储的,元素删除后,后续元素会前移。 但一些场景中,我们又需要在执行删除操作…...
elementUI点击浏览table所选行数据查看文档
项目场景: table按照要求特定的数据变成按钮可以点击 解决方案: <el-table-columnprop"mlname"label"名称"align"center"width"180"><template slot-scope"scope"><el-buttonv-if&qu…...
