Mybatis工作原理

本文深入探讨了MyBatis框架的起源与演变,从iBatis到MyBatis的迁移,详细分析了其核心配置文件mybatis-config.xml及mapper映射文件的作用。通过源码分析,揭示了SqlSessionFactory、SqlSession及动态代理对象的工作机制,展示了如何通过执行器Executor执行SQL语句,以及数据查询和结果封装的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Mybatis它的前身是 iBatis,Apache 的一个开源项目,在2010年这个项目从 Apache 迁移到 Google Code 改名为 Mybatis

Mybatis是数据访问层框架,我们可以用它来操作数据库,接下来我们看下Mybatis的源码分析:

1、mybatis的相关配置信息

  • mybatis-config.xml

enter image description here

这里面主要配置了数据源信息即数据库连接信息和包含Sql语句的mapper映射文件

 

  • xxMapper.xml

enter image description here

映射文件的配置信息,这里面包含了接口路径、sql语句、参数类型、返回类型、返回结果集类型等等

2、源码分析

首先我们看看我们的main函数

  • 获取SqlSessionFactory对象

enter image description here

这里面我们通过读取配置文件mybatis-config.xml,获取输入流对象Reader,然后通过

new SqlSessionFactoryBuilder().build( reader )

方法获取SqlSessionFactory对象

  • 获取SqlSession对象

enter image description here

这里通过openSession方法获取SqlSession

  • 获取接口对象

enter image description here

通过getMapper方法获取接口对象,这里的mapper其实是一个动态代理对象,包含了SqlSessiond对象,如下图:

enter image description here

那么就可以通过SqlSession对象中的执行器Excutor来执行sql语句

  • 执行接口对象的增删改查方法

enter image description here

通过执行接口对象中的findById方法来触发执行器,执行Sql语句,然后将查询结果封装到返回类型中返回,打印用户信息如下

User{id=1, username='admin', password='admin'}

到这里我们就从数据库中获取到了数据

3、Mybatis工作原理流程图

enter image description here

访问我的达人课

我的微信公众号

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

坏菠萝

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值