首页 > 其他分享 >【MyBatis 核心工作机制】注解式开发与动态代理原理

【MyBatis 核心工作机制】注解式开发与动态代理原理

时间:2024-12-29 23:29:44浏览次数:8  
标签:数据库 代理 SqlSession SQL MyBatis 注解

有很多朋友可能已经在开发中熟练使用 MyBatis  或者刚开始学习 MyBatis,对于它的一些工作机制不太了解。“咦,怎么写几个注解,写几个配置文件,就能实现这些效果呢,好神奇呀!”当你看完这篇博客之后,你会不经赞叹 MyBatis 框架设计者的巧妙,并且会帮助你理解这个工作机制。


还是先大致介绍一下 Mybatis,在现代 Java 开发中,MyBatis 是一个非常流行的持久层框架,它帮助我们简化了数据库操作,减少了重复代码,并提升了开发效率。今天,我们将重点探讨 MyBatis 中的注解式开发和它背后的动态代理机制。通过理解这些核心概念,你将能够更高效地使用 MyBatis 进行数据库交互。


一、什么是 MyBatis 注解式开发?

我们先来简单回顾一下 MyBatis 的基本概念。MyBatis 是一个半自动化的 ORM(对象关系映射)框架,它通过 SQL 映射文件(XML 或注解)将 Java 对象与数据库表中的数据进行映射。与传统的 JDBC 操作相比,MyBatis 提供了更简洁的代码和更灵活的 SQL 操作方式。

在注解式开发中,我们将 SQL 语句直接写在 Java 接口的方法上,MyBatis 会根据这些注解自动执行相应的 SQL。这种方式简化了传统 XML 配置,适用于一些简单、直接的数据库操作。

二、核心机制:SqlSessionFactory 和 SqlSession

1. SqlSessionFactory 的作用

无论是使用 XML 还是注解,SqlSessionFactory 都是 MyBatis 的核心。它的主要任务是解析配置文件、创建 SqlSession 实例,并初始化所有相关的环境配置。通过 SqlSessionFactory,我们可以访问数据库和执行 SQL。

SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder()
    .build(Resources.getResourceAsStream("mybatis-config.xml"));

在注解式开发中,SqlSessionFactory 会根据我们提供的配置文件来加载数据库连接、事务管理等信息,并为每个数据库操作生成 SqlSession 对象。

2. SqlSession 的核心作用

SqlSession 是与数据库交互的关键对象,它负责执行 SQL 语句、管理事务,并返回查询结果。在注解式开发中,SqlSession通过动态代理的方式创建 Mapper 接口的实例,从而完成数据库操作。

try (SqlSession session = sqlSessionFactory.openSession()) {
    UserMapper mapper = session.getMapper(UserMapper.class);
    User user = mapper.selectUserById(1);
    System.out.println(user.getName());
}

在这个代码中,SqlSession 通过 session.getMapper(UserMapper.class) 获取到一个动态代理的 UserMapper 接口对象,并执行查询操作。


三、Mapper 接口:动态代理的神奇之处

1. 什么是 Mapper 接口?

Mapper 接口是 MyBatis 提供的一种方式,用于将 SQL 操作封装为 Java 接口方法。每个方法对应一个 SQL 语句,在运行时,MyBatis 会为这些方法生成代理类,通过动态代理来执行实际的数据库操作

在注解式开发中,@Select@Insert 等注解用于直接定义 SQL 语句,而 MyBatis 会根据这些注解的内容来生成相应的 SQL 执行逻辑。

2. 动态代理的工作原理

MyBatis 使用 Java 的动态代理机制java.lang.reflect.Proxy)为每个 Mapper 接口创建代理对象。当调用 mapper.selectUserById(1) 时,代理对象会拦截这个方法调用,解析方法名,并执行相应的 SQL。

这种代理机制的核心是 MapperProxy 类,它负责将方法调用转发给 SqlSession 来执行实际的数据库操作。

UserMapper mapper = sqlSession.getMapper(UserMapper.class); // 动态代理生成
mapper.selectUserById(1); // 实际调用时被代理拦截

在执行过程中,MapperProxy 会根据方法的名称、参数以及注解中的 SQL 信息来确定要执行的 SQL 语句,并通过 SqlSession 来完成 SQL 执行。

3. 注解的工作机制

MyBatis 提供了多种注解来简化 SQL 的编写,最常用的有 @Select@Insert@Update@Delete。这些注解会将 SQL 语句绑定到对应的接口方法上,并且 MyBatis 会在初始化时解析这些注解,确保每个方法能够正确执行相应的 SQL。

例如:

@Mapper
public interface UserMapper {
    @Select("SELECT * FROM user WHERE id = #{id}")
    User selectUserById(@Param("id") int id);
}

在这个例子中,@Select 注解将 SQL 语句绑定到 selectUserById 方法,MyBatis 会自动生成对应的执行逻辑。调用 mapper.selectUserById(1) 时,MyBatis 会解析 SQL 并执行查询操作。


四、SqlSessionMapper 的协作

  1. Mapper 通过 SqlSession 执行 SQL:在 MyBatis 中,Mapper 接口的每个方法都通过 SqlSession 执行 SQL 查询或更新操作。

  2. 事务管理SqlSession 提供了提交、回滚和关闭的方法,以确保事务的一致性。在注解式开发中,事务管理仍然由 SqlSession 负责。

try (SqlSession sqlSession = sqlSessionFactory.openSession()) {
    UserMapper mapper = sqlSession.getMapper(UserMapper.class);
    User user = mapper.selectUserById(1); // 执行 SQL 查询
    sqlSession.commit(); // 提交事务
}

通过这种方式,SqlSession 确保了数据库操作的事务一致性和执行效率。


五、总结:MyBatis 注解式开发的优势

  • 简化配置:注解式开发无需编写复杂的 XML 配置,SQL 直接写在 Java 方法上,减少了配置的复杂度。
  • 高效开发:通过动态代理机制,MyBatis 可以自动为我们生成数据库操作的执行逻辑,简化了代码结构。
  • 灵活性:虽然注解式开发适用于简单的 SQL 操作,但对于复杂的查询或多表关联,MyBatis 仍然推荐使用 XML 配置。

MyBatis 在注解式开发中的优势显而易见,它不仅提高了开发效率,还减少了 SQL 语句与 Java 代码的耦合度。通过理解 SqlSession 和动态代理的机制,你将能够更好地利用 MyBatis 进行高效的数据库操作。


希望通过这篇文章,你能对 MyBatis 的注解式开发和动态代理原理有更深入的理解,并能够灵活运用它们来优化你的项目开发。

标签:数据库,代理,SqlSession,SQL,MyBatis,注解
From: https://blog.csdn.net/Fang_20/article/details/144724605

相关文章

  • 【Mybatis歌剧院】开发人员常用的操作数据库效率贼快的框架——Mybatis, 工作常用,面试
    本篇会加入个人的所谓鱼式疯言❤️❤️❤️鱼式疯言:❤️❤️❤️此疯言非彼疯言而是理解过并总结出来通俗易懂的大白话,小编会尽可能的在每个概念后插入鱼式疯言,帮助大家理解的.......
  • 【Nginx应用】nginx stream模块代理MySQL
    其实使用开发机器的nginx一样可以代理数据库,从而实现办公网访问数据库。一、stream模块介绍Nginx的TCP/UDP代理功能的模块分为核心模块和辅助模块。核心模块stream需要在编译配置时增加“--with-stream”参数进行编译【但是我测试的时候,我的开发机并不是这么安装的,直接yumiins......
  • Mybatis 如何分页?
     作者简介:大家好,我是码炫码哥,前中兴通讯、美团架构师,现任某互联网公司CTO,兼职码炫课堂主讲源码系列专题代表作:《jdk源码&多线程&高并发》,《深入tomcat源码解析》,《深入netty源码解析》,《深入dubbo源码解析》,《深入springboot源码解析》,《深入spring源码解析》,《深入redis源......
  • Mybatis 插件的工作原理?
     作者简介:大家好,我是码炫码哥,前中兴通讯、美团架构师,现任某互联网公司CTO,兼职码炫课堂主讲源码系列专题代表作:《jdk源码&多线程&高并发》,《深入tomcat源码解析》,《深入netty源码解析》,《深入dubbo源码解析》,《深入springboot源码解析》,《深入spring源码解析》,《深入redis源......
  • AI代理:构建智能自主性的明智方法
    AI代理:构建智能自主性的明智方法引言在当今的科技环境中,自主性被视为AI系统的核心特征。随着诸如Salesforce和HubSpot等技术巨头的推陈出新,诸多企业声称他们的AI代理具有革命性变化的潜力。然而,当前市场上许多AI代理的表现远未达到“完全自主”的标准。这引发了一个重要问......
  • 注解Annotation
    简介注解Annotation,又称为java标注,从JDK5.0开始被支持。用来修饰类,属性,方法,参数,局部变量等等,在编译,类加载和运行时被读取并做相应处理。四大元注解@Target(必须)标识当前注解在什么地方使用属性ElementType@Retention(必须标识当前注解使用的级别(作用级别)属性RetentionPoli......
  • 2024-11-28《关于mybatis创建的mapper映射路径不对导致的系列报错》
    关于mybatis创建的mapper映射路径不对导致的系列报错 今天在写mybatis项目的时候,使用注解发现无法使用别名,添加ResultMap的时候直接报错显示无法解析。经过百度了好久也是成功的发现了问题的所在,就是这个:这个路径创建的时候我以为创建的是分级目录,实际上创建成为了com.inn......
  • 主动式AI(代理式)与生成式AI的关键差异与影响
    大型语言模型(LLMs)如GPT可以生成文本、回答问题并协助完成许多任务。然而,它们是被动的,这意味着它们仅根据已学到的模式对接收到的输入作出响应。LLMs无法自行决策;除此之外,它们无法规划或适应变化的环境。主动式AI(代理式)的出现正是为了解决这一问题。与生成式AILLMs不同,主动式AI(......
  • 掌握MyBatis:从入门到精通的全方位指南
    mysql缓存:根据sql语句进入缓存,如果sql语句多加一个空格就进入不到同一个缓存,另外数据库数据发生了更新,缓存中的数据不会同步。延迟加载:先查询基本信息,再查询其他信息(相亲网站),而不是一次就查询出来。mybatis的框架概述数据库厂商都会有自己的驱动包,上面一......
  • mybatis一对多collection select
     mybatis一对多collectionselect在MyBatis中,处理一对多关系时,通常会在映射文件中使用<collection>元素,并在其中嵌套一个<select>元素来实现对关联表的查询。这种方式允许你从一个表(称为“一”的一方)中查询数据,并同时获取与其关联的多个表(称为“多”的一方)中的数据......