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

Myabits的执行过程

1. 加载配置文件

  • MyBatis 会首先加载配置文件(通常是mybatis-config.xml),这个配置文件中包含了数据库连接相关的配置信息,比如数据库的驱动类、连接地址、用户名、密码等,同时也可以配置诸如类型别名、插件、映射器(mapper)等相关的全局设置信息。例如:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration
  PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
  "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.cj.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/mydb?useSSL=false"/>
                <property name="username" value="root"/>
                <property name="password" value="123456"/>
            </dataSource>
        </environment>
    </environments>
    <mappers>
        <mapper resource="com/example/mapper/UserMapper.xml"/>
    </mappers>
</configuration>

2. 构建 SqlSessionFactory

  • 根据加载的配置文件,MyBatis 会创建一个SqlSessionFactory对象。这个对象是线程安全的,在整个应用程序的生命周期内通常只需要创建一次,它是后续创建SqlSession的工厂类,负责生产可以与数据库进行交互的SqlSession实例。创建过程一般通过如下代码实现:

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

3. 获取 SqlSession

  • SqlSessionFactory中获取SqlSession对象,SqlSession就像是一个数据库连接会话,它提供了众多操作数据库的方法,比如执行查询、插入、更新、删除等操作。不过要注意的是,SqlSession不是线程安全的,所以通常在每次需要和数据库交互时获取,使用完后及时关闭。示例代码如下:

SqlSession sqlSession = sqlSessionFactory.openSession();

4. 查找映射语句(Mapper)

  • 当需要执行某个具体的数据库操作时(比如查询用户信息),MyBatis 会根据接口(通常是 Mapper 接口)和对应的 XML 映射文件(或者基于注解的映射方式)去查找对应的 SQL 语句定义。例如,有一个UserMapper接口及其对应的UserMapper.xml映射文件,在接口中定义了方法:
public interface UserMapper {
    User getUserById(int id);
}

对应的 XML 映射文件中会定义具体的 SQL 语句:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
  PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.mapper.UserMapper">
    <select id="getUserById" resultMap="UserResultMap">
        select * from users where id = #{id}
    </select>
</mapper>

5. 执行 SQL 语句

  • 通过SqlSession调用对应的 Mapper 接口方法(实际上底层会根据映射找到对应的 SQL 语句去执行),如果是查询操作,会将结果按照配置的结果映射规则(如通过resultMap等方式)进行转换,返回对应的 Java 对象(比如上述的User对象)。示例代码如下:
UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
User user = userMapper.getUserById(1);

6. 处理结果

  • 对于查询操作得到的结果,会根据配置的映射规则将数据库中的数据转换为 Java 对象或者集合等合适的数据结构。如果是更新、插入、删除操作,会返回相应的受影响行数等信息,以让调用者知晓操作的执行情况。

7. 关闭 SqlSession

  • 当完成与数据库的交互后,需要关闭SqlSession,释放相关资源,防止资源泄露。可以通过如下方式关闭:
sqlSession.close();

总的来说,MyBatis 通过这样一套流程实现了 Java 代码与数据库操作的解耦,方便、高效地进行数据库交互,并且能灵活地配置和定制 SQL 语句以及结果映射等相关内容。


http://www.kler.cn/a/442827.html

相关文章:

  • AI浪潮下的IT变革之路:机遇、挑战与重塑未来
  • Centos8部署Redis Cluster
  • 30天开发操作系统 第 12 天 -- 定时器 v1.0
  • 分布式一致性CAP与BASE理论、分布式一致性协议和算法——2PC、3PC 和 Paxos算法
  • Vue3初学之组件通信
  • TCPIP网络编程
  • Eureka控制中心:微服务控制的极速上手指南
  • WPF+MVVM案例实战与特效(四十一)-WPF文本到几何路径转换的艺术:轻松实现自定义字体路径生成
  • Linux: 通过/proc/pid/stack查看程序卡在内核的什么地方
  • Python 实现炸弹人游戏
  • 智星云技术文档:GPU测速教程
  • Java中基于TCP的Socket编程
  • API开发:Flask VS FastAPI
  • 基于RK3588机器人控制器+3D视觉传感器的送餐机器人解决方案
  • 网络编程 02:IP 地址,IP 地址的作用、分类,通过 Java 实现 IP 地址的信息获取
  • 用 Python 格式化器重新定义用户体验
  • open-cv机器视觉相关知识
  • 蓝桥杯刷题——day6
  • 心法利器[122] | 算法面试的八股和非八股讨论
  • 借 SSM 之力,以 Vue 为笔绘就新锐台球厅管理系统设计与实现蓝图
  • NDRCContextUnmarshall断点函数分析之I_RpcBindingCopy函数的作用
  • oracle控制文件发生变化的情况
  • 介绍几个Linux下的杀毒软件
  • 重新定义页签!Choerodon UI Tabs让管理更高效
  • Vue-Form-Making:Star5.5k,一款强大的Vue表单设计器,适用于低代码平台、自定义表单
  • ABAP SQL 取日期+时间最新的一条数据