(转自掘金pj童鞋)浅析MyBatis的动态代理原理

目录

参考文章

个人总结


参考文章

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信息,执行相应的逻辑,返回结果。

发布了213 篇原创文章 · 获赞 31 · 访问量 19万+

猜你喜欢

转载自blog.csdn.net/weixin_38336658/article/details/102309331