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