1.mybatis结构总览

1、mybatis简单 demo

@Before
public void beforeMybatis() throws IOException {
  String resource = "com/scarecrow/mybatis/config/mybatis-config.xml";
  InputStream inputStream = Resources.getResourceAsStream(resource);
  Properties properties = new Properties();
  properties.setProperty("password", "scarecrow");
  sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream, "development1", properties);
}
@Test
public void simpleGetUser() {
  try (SqlSession sqlSession = sqlSessionFactory.openSession(true)) {
    Map<String, Object> paramMap = new HashMap<>();
    paramMap.put("userId", 20L);
    paramMap.put("userName", "insert");
    UserPO userPO = sqlSession.selectOne("com.scarecrow.mybatis.mapper.UserMapper.simpleGetUser", paramMap);
    System.out.println(new ObjectMapper().writeValueAsString(userPO));
  } catch (JsonProcessingException e) {
    e.printStackTrace();
  }
}
<select id="simpleGetUser" resultMap="resultMap">
  select
  <include refid="base_column"/>
  from tb_user
    where user_id = #{userId, jdbcType=BIGINT}
  <if test="userName != null and userName != ''">
    and USER_NAME = #{userName, jdbcType=VARCHAR}
  </if>
</select>

mybatis相关的实际上就只有三步:创建SqlSessionFactory、通过SqlSessionFactory创建SqlSession、SqlSession执行selectOne方法。具体的执行原理稍后分析

2、mybatis 体系结构介绍

image-20210428215650467

mybatis 的执行流程如下:

  • 首先通过 Java API 或者 XML 配置完成初始化,最终所有的配置都在 Configuration 类中维护;
  • 然后通过 SqlSessionFactory 得到 SqlSession,这里 SqlSession 就是 mybatis 的顶层 API 了,主要通过他完成数据库的增删改查等操作;
  • 然后 SqlSession 将具体的操作委托给 Executor 执行,Executor 就是 mybatis 的调度核心了,主要职责有 SQL 语句生成、一二级缓存维护和事务的相关操作;
  • 然后 Executor 将数据库相关的操作委托给 StatementHandler,StatementHandler 中完成了 mybatis 最核心的工作,包括参数绑定,指定 SQL 语句,结果集映射等;

具体过程如图所示:

mybatis 最核心的工作,包括参数绑定,指定 SQL 语句,结果集映射等;

具体过程如图所示:

image-20210428215808501

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值