MyBatis实战之工作执行流程

前文回顾

上一篇文章我们主要讲了MyBatis是什么、有什么优点,有什么缺点以及应用场景,然后结合一个实战中使用的方式做了一个增删改查的小demo。这篇文章我们就来看看MyBatis的工作流程是怎样的。

工作示例

<?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.kyle.xml.mapper.UserMapper">
    <!-- 添加 -->
    <insert id="add">
        insert into user(id,account,password,age) values(#{id},#{account},#{password},#{age})
    </insert>
</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>
    <!-- 开启mybatis 日志 -->
    <settings>
        <setting name="logImpl" value="LOG4J"/>
    </settings>
    <environments default="development">
        <environment id="development">
            <!-- JDBC 事务处理 -->
            <transactionManager type="JDBC"/>
            <!-- 使用默认连接池 -->
            <dataSource type="POOLED">
                <!-- mysql 数据库驱动 ,注意5.0版本和8.0以上版本 不一致 -->
                <property name="driver" value="com.mysql.cj.jdbc.Driver"/>
                <!-- 数据库链接 URL 可替换自己的数据库名 -->
                <property name="url"
                          value="jdbc:mysql://127.0.0.1:3306/kyle?serverTimezone=Asia/Shanghai&amp;allowPublicKeyRetrieval=true&amp;useSSL=false"/>
                <!-- 数据库用户名 -->
                <property name="username" value="root"/>
                <!-- 数据库密码 -->
                <property name="password" value="Kyle_123456"/>
            </dataSource>
        </environment>
    </environments>
    <mappers>
        <mapper resource="com/kyle/xml/mapper/UserMapper.xml"/>
    </mappers>
</configuration>
 // 配置文件路径,文件名是自定义的,在这里配置文件里面只有数据库相关的环境信息和Mapper映射文件
    String resource = "mybatis-config.xml";
    InputStream inputStream = null;
    SqlSession sqlSession = null;
    try {
        // 将配置文件读取并转换成流文件
        inputStream = Resources.getResourceAsStream(resource);
        // 创建会话工厂
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        // 创建会话
        sqlSession = sqlSessionFactory.openSession();
        // 获取已经创建好的Mapper接口
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        // 使用了动态代理的方式调用方法,追中转换成sql并执行
        mapper.add(user);
        // 提交事务,如果事务不提交则无法保存数据
        sqlSession.commit();
    } catch (IOException e) {
        e.printStackTrace();
    } finally {
        // 关闭会话释放资源
        if (sqlSession != null) {
            sqlSession.close();
        }
    }

上面演示了添加一个用户的Java代码示例,使用步骤如下:

  1. 创建一个UserMapper.xml,里面填写sql语句
  2. 创建一个mybatis-config.xml的配置文件,里面包含上面添加的UserMapper.xml和数据库链接、事务的简单配置。
  3. 创建一个UserMaper接口和UserMapper.xml为映射关系
  4. 读取mybatis-config.xml配置文件中的信息,创建SqlSessionFactory 创建会话工厂。
  5. 创建SqlSession会话
  6. 获取UserMapper接口
  7. 调用UserMapper中的add方法
  8. 提交事务
  9. 最后关闭会话释放资源

上面示例介绍了MyBatis的简单使用流程,也是对MyBatis的加深理解,下面将一下具体的工作原理。

工作流程

配置文件

配置文件我会拿出一个单独的章节来进行具体介绍,这里我们只介绍数据库连接信息和SQL代码。数据库连接信息这里我们只填写了使用JDBC的事务和使用mysql的驱动连接数据库,Mapper文件中写SQL语句以达到和java代码分离,也方便统一管理和优化。配置文件中的信息最终会映射为Java代码,而底层使用的XPath解析xml,读出对应的参数到相对应的类中。

创建会话工厂

使用SqlSessionFactoryBuilder 创建会话工厂,默认生成的是DefaultSqlSessionFactory,内部使用XPathParser 解析xml文件
在这里会注册MapperProxy动态代理,创建MapperRegistry,方便以后执行接口Mapper,sql的参数和返回结果等相关参数解析到MappedStatement中。

创建会话对象

使用会话工厂sqlSessionFactory.openSession()创建会话,这里会创建事务和Executor执行器并返回DefaultSqlSession实例对象。

获取UserMapper接口

这里的接口是在创建会话的时候就已经注册好的,从Map中取出来使用。

Executor执行SQL

无论是使用反射还是代码最终都由Executor来实现sql的操作,默认使用的是SimpleExecutor,这里首先会获取数据库连接,然后创建一个StatementHandler去执行真正的sql操作。

提交事务

最后一步操作就是提交事务了,这里不再过多赘述。

工作流程图

在这里插入图片描述

总结

上面我们介绍了MyBatis工作的执行流程,流程很简单,但是真正阅读的时候代码量还是很大的,建议大家按照这个流程,自己走一遍断点测试,真正的理解MyBatis是如何工作的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

实战小白

如果对你有帮助请我抽一颗烟

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

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

打赏作者

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

抵扣说明:

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

余额充值