目录
参考文章
https://juejin.im/post/5cd4355be51d453a5143306c
在我debug模式追踪PageHelper源码的时候也追到那个update/select/insert...那一段就是执行的时候,但是就好奇为啥我执行mapper的时候是怎么产生代理类的。
上面的文章解开了我的疑惑,我们平时都是交给Spring容器去创建,所以不用去考虑考虑到这一步。
看下关键代码
public class MybatisTest {
private static SqlSessionFactory sqlSessionFactory;
static {
try {
sqlSessionFactory = new SqlSessionFactoryBuilder()
.build(Resources.getResourceAsStream("mybatis-config.xml"));
} catch (IOException e) {
e.printStackTrace();
}
}
public static void main(String[] args) {
try (SqlSession sqlSession = sqlSessionFactory.openSession()) {
//生成代理类,从Configuration获取相应的mapper,执行相关的CURD操作
UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
User user = userMapper.selectById(1);
System.out.println("User : " + user);
}
}
}
// 结果:
User : User{id=1, age=21, name='pjmike'}
核心类:sqlSession
我们平时是@Resource xxMapper xxMapper进行调用,也就是由容器去处理。具体源码分析看下上面西电的pj童鞋
个人总结
Mybatis的原理:先加载配置到Configuration,然后应用访问mapper的时候,会去Configuration的getMapper方法获取相关注册到这里的mapper,然后SqlSessionFactoryBuilder去创建工厂SqlSessionFactory,再创建SqlSession。open这个sqlSession,通过MapperProxy代理类去Configuration拿到注册的Mapper信息,执行相应的逻辑,返回结果。