mybatis框架的orm机制(类和数据库表的映射)

MyBatis框架之所以能够将数据库表映射到Java类,其核心原理是基于对象关系映射(ORM)。ORM是一种编程技术,用于在关系型数据库和面向对象编程语言之间建立映射关系,从而实现数据库表和对象之间的转换。

MyBatis实现映射的基本原理:

  1. 配置映射关系: 在MyBatis的映射文件中,开发者需要配置数据库表和Java类之间的映射关系。这通常通过XML或注解的方式完成。映射文件中包含了表的结构、字段和对应的Java类的属性,以及SQL语句的配置。

  2. 创建对应的Mapper接口,创建对应的方法,然后再对应的Mapper配置文件中进行映射

    映射的两个一致:

    1.Mapper.xml文件中的namespase需要与对应接口的全类名保持一致

    2.xml文件中的对应方法标签的id需要与mapper接口中的方法名一致

    然后sqlSession的getMappe方法在调用时,会根据对应接口的字节码文件

    自动创建该接口的实现类对象,并根据接口中的方法名去匹配对应xml文件中的id

    执行对应的sql语句,并将结果返回给mapper对象

    <!-- UserMapper.xml --><resultMap id="BaseResultMap" type="com.example.User"><id column="id" property="id" jdbcType="BIGINT"/><result column="username" property="username" jdbcType="VARCHAR"/><result column="email" property="email" jdbcType="VARCHAR"/>
    </resultMap><select id="getUserById" resultype="User">SELECT * FROM users WHERE id = #{id}
    </select>
    

    3.ORM框架的执行: 当执行数据库操作时,MyBatis根据配置的映射关系,自动将数据库查询结果映射为Java对象。这包括了查询结果集中的每一行记录,每个字段的值被映射到Java对象的相应属性上。

// 使用MyBatis进行数据库操作
UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
User user = userMapper.getUserById(1L);

 4.类型处理器(Type Handler): MyBatis通过类型处理器将数据库的数据类型转换为Java中的数据类型。类型处理器负责在数据库查询和Java对象之间进行数据类型的转换,确保数据的正确映射。

public class User {private Long id;private String username;private String email;// Getters and setters
}

5.SQL语句的执行: MyBatis执行配置的SQL语句,将数据库表中的数据提取出来,然后通过ORM框架将数据映射到Java对象上。

总体而言,MyBatis的映射原理通过配置文件指定了数据库表和Java对象之间的映射关系,利用类型处理器进行数据类型的转换,然后通过SQL语句的执行将数据库表的数据映射到Java对象上。这样,开发者可以更方便地使用面向对象的方式进行数据库操作,而不必直接处理SQL语句和结果集。

在ORM框架中,将数据映射到Java对象的核心步骤涉的底层执行:

  1. ResultSet的处理: ORM框架通过JDBC从数据库中获取的查询结果是一个ResultSet对象。底层ORM框架需要对ResultSet进行处理,逐行读取数据并转换为Java对象的属性。

  2. 反射机制: 反射是Java语言的一个重要特性,它允许在运行时动态获取类的信息并操作类的成员。ORM框架使用反射机制来实现数据库表和Java对象之间的映射。通过反射,框架可以获取Java类的字段信息,然后通过字段名与数据库列的对应关系,将查询结果中的数据设置到Java对象的相应属性上。/

    // 通过反射设置属性值的示例
    Field field = User.class.getDeclaredField("username");
    field.setAccessible(true);
    field.set(userInstance, "JohnDoe");
    
  3. 类型处理器(Type Handler): ORM框架使用类型处理器来处理数据库和Java之间的数据类型转换。类型处理器负责将数据库中的数据类型转换为Java对象中对应的数据类型,以确保数据的正确映射。

    // 类型处理器示例
    public class StringTypeHandler implements TypeHandler<String> {@Overridepublic void setParameter(PreparedStatement ps, int i, String parameter, JdbcType jdbcType) throws SQLException {// 设置PreparedStatement的参数ps.setString(i, parameter);}@Overridepublic String getResult(ResultSet rs, String columnName) throws SQLException {// 从ResultSet中获取结果return rs.getString(columnName);}// 其他方法...
    }
    

    4.实例化Java对象: 在将数据设置到Java对象的属性之前,需要先实例化Java对象。ORM框架通过调用Java类的构造函数或者其他实例化的方式来创建Java对象。

    // 实例化Java对象的示例
    User user = User.class.newInstance();
    

    总体而言,底层ORM框架通过ResultSet处理、反射机制、类型处理器、实例化Java对象等步骤,将数据库查询结果映射到Java对象上。这样,开发者在使用ORM框架时无需手动编写繁琐的数据转换和赋值逻辑,通过简洁的配置和使用,实现了数据库和Java对象之间的无缝映射。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/231993.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

对私域的认知,决定了你的私域能做多久!

现在&#xff0c;大部分企业对私域的认知是扭曲的。 比如&#xff0c;说到做私域&#xff0c;很多企业都是忙着往企业微信拉人&#xff0c;做自己的小程序商城来卖货。大多数企业就这样把私域当成了企业的独有“淘宝天猫”&#xff0c;这样做私域&#xff0c;可能会带来短期GM…

Flink系列之:Table API Connectors之Debezium

Flink系列之&#xff1a;Table API Connectors之Debezium 一、Debezium二、依赖三、使用Debezium Format四、可用元数据五、Format参数六、重复的变更事件七、消费 Debezium Postgres Connector 产生的数据八、数据类型映射 一、Debezium Debezium 是一个 CDC&#xff08;Chan…

在 Windows 上安装并配置 dig命令 的步骤

介绍&#xff1a;dig 是一个网络工具&#xff0c;通常在 Unix 和类 Unix 系统上使用&#xff0c;用于查询 DNS&#xff08;域名系统&#xff09;信息。它可以用来获取域名相关的信息&#xff0c;比如 IP 地址、域名服务器的记录等。你可以使用 dig 命令来进行域名解析、查找特定…

Spring之手写IoC

学习的最大理由是想摆脱平庸&#xff0c;早一天就多一份人生的精彩&#xff1b;迟一天就多一天平庸的困扰。各位小伙伴&#xff0c;如果您&#xff1a; 想系统/深入学习某技术知识点… 一个人摸索学习很难坚持&#xff0c;想组团高效学习… 想写博客但无从下手&#xff0c;急需…

DALL-E 系列:AI绘画背后的惊人真相!!【1个离奇内幕、3个意想不到、5大秘密揭示】

DALL-E 系列&#xff1a;AI绘图原理&#xff0c;根据用户给出的描述&#xff0c;生成与描述相匹配的图像 DALL-E 1dVAETransformer DALL-E 2CLIP先验 priordecoder&#xff08;image&#xff09; DALL-E 3 论文地址&#xff1a;https://arxiv.org/pdf/2102.12092.pdf DALL-E 的…

Android 原始方法实现Tablayout样式

源码&#xff1a; 【免费】Android原始方法实现Tablayout样式资源-CSDN文库 推荐&#xff1a; GitHub - hackware1993/MagicIndicator: A powerful, customizable and extensible ViewPager indicator framework. As the best alternative of ViewPagerIndicator, TabLayout …

PowerShell实战(一)PowerShell使用ImportExcel模块轻松操作Excel

目录 一、介绍 二、安装模块 三、操作示例 1、导出excel 2、读取Excel数据 3、导出包含图表的Excel 4、导出包含汇总列和图表的Excel 一、介绍 ImportExcel模块可以理解为基于PowerShell环境操作Excel的强大类库&#xff0c;使用它可以在 Windows、Linux 和 Mac 上都可以使用。…

119. 杨辉三角 II

描述 : 给定一个非负索引 rowIndex&#xff0c;返回「杨辉三角」的第 rowIndex 行。 在「杨辉三角」中&#xff0c;每个数是它左上方和右上方的数的和 题目 : LeetCode 119. 杨辉三角 II : 119. 杨辉三角 II 分析 : 这道题用二维数组来做 . 解析 : class Solution {pub…

企微私域裂变:数字化时代的企业增长新引擎

在当前的数字化时代&#xff0c;企业面临着客户获取和转化的挑战。为了解决这一问题&#xff0c;企微私域裂变作为一种新型的营销策略&#xff0c;逐渐受到企业的关注。通过精细化的运营、深入的用户洞察和创新的裂变手段&#xff0c;企微私域裂变帮助企业快速拓展市场&#xf…

GPT-4V with Emotion:A Zero-shot Benchmark forMultimodal Emotion Understanding

GPT-4V with Emotion:A Zero-shot Benchmark forMultimodal Emotion Understanding GPT-4V情感:多模态情感理解的zero-shot基准 1.摘要 最近&#xff0c;GPT-4视觉系统(GPT-4V)在各种多模态任务中表现出非凡的性能。然而&#xff0c;它在情感识别方面的功效仍然是个问题。本文定…

IDEA版SSM入门到实战(Maven+MyBatis+Spring+SpringMVC) -Spring的AOP前奏

第一章 AOP前奏 1.1 代理模式 代理模式&#xff1a;我们需要做一件事情&#xff0c;又不期望自己亲力亲为&#xff0c;此时&#xff0c;可以找一个代理【中介】 我们【目标对象】与中介【代理对象】不能相互转换&#xff0c;因为是“兄弟”关系 1.2 为什么需要代理【程序中…

JavaScript中audio停止播放事件

在HTML中&#xff0c;使用JavaScript来控制<audio>元素的播放和停止。要停止播放音频&#xff0c;使用pause()方法。 以下是一个示例&#xff0c;展示了如何使用JavaScript来停止播放音频&#xff1a; <!DOCTYPE html> <html> <body><audio id&qu…

css+html横向滚动+固定宽

没什么好说的&#xff0c;快上代码&#xff01; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Do…

微服务实战系列之ZooKeeper(上)

前言 历经1个多月的创作和总结&#xff0c;纵观博主微服务系列博文&#xff0c;大致脉络覆盖了以下几个方面&#xff1a; 数据方面&#xff08;缓存&安全&#xff09; 比如Redis、MemCache、Ehcache、J2cache&#xff08;两级缓存框架&#xff09;、RSA加密、Sign签名…传…

Pycharm enable IntelliBot #patched后,工程无法打开

#本地环境# Pycharm&#xff1a;2023.12 Pro 对应robot pkg版本&#xff1a; robotframework 6.1 robotframework-databaselibrary 1.2.4 robotframework-pythonlibcore 4.1.2 robotframework-requests 0.9.4 robotframework-seleniumlibrary 6.1.…

各种不同语言分别整理的拿来开箱即用的8个开源免费单点登录(SSO)系统

各种不同语言分别整理的拿来开箱即用的8个开源免费单点登录&#xff08;SSO&#xff09;系统。 单点登录&#xff08;SSO&#xff09;是一个登录服务层&#xff0c;通过一次登录访问多个应用。使用SSO服务可以提高多系统使用的用户体验和安全性&#xff0c;用户不必记忆多个密…

Linux 操作系统 012-磁盘分区机制

Linux 操作系统 012-磁盘分区机制 本节关键字&#xff1a;Linux、磁盘分区 本节相关指令&#xff1a;fdisk、mount、umount、ls、df、du 磁盘分区原理 Linux无论有几个分区&#xff0c;都给那一目录使用&#xff0c;归根结底就只有一个根目录&#xff0c;一个独立且唯一的文…

electron与cesium组件入门应用功能

electron与cesium组件入门应用功能 运行应用效果图&#xff1a; electron应用目录&#xff0c;需要包括三个文件: index.html main.js package.json (一)、创建一个新项目 目录名称&#xff1a;project_helloWolrd (二)、生成package.json文件 npm init --yes(三&#x…

iptables禁用国外IP

iptables官网 iptables封禁国外IP–博客园–good iptables结合ipset禁用国外IP访问服务器 iptables禁用国外IP–周一自动更新ip库 iptables封禁国外IP的办法–csdn–凌晨两点更新 iptables封禁国外IP的办法–51cto–复制了ip库 腾讯文档–宝塔面板封禁办法 另外的IP库 使用ipt…

短视频账号矩阵系统3年技术独立源头正规开发搭建

短视频账号矩阵3年技术独立开发打造是一个非常有挑战性和前景的项目。以下是一些建议&#xff0c;帮助你成功打造一个成功的短视频账号矩阵&#xff1a; 1. 确定目标受众&#xff1a;首先需要明确你的目标受众是谁&#xff0c;了解他们的兴趣爱好、年龄、性别等&#xff0c;以便…