• Mybatis Plus动态代理源码分析


    以下以调用baseMapper的selectById为例,剖析Mybatis plus的执行逻辑。

    总体来看,Mybatis plus通过两层JDK动态代理的方式,实现了SQL的执行。

    第一层动态代理为:MybatisMapperProxy,内部获取到了SqlSessionInterceptor;

    第二层动态代理为:SqlSessionInterceptor,内部真正的创建了SqlSession来执行SQL并返回。

    1、主入口:

    此时会通过JdkDynamicAopProxy通过反射的方式,调用MybatisMapperProxy,此类为所有Mybatis plus SQL执行的主入口。

    2、MybatisMapperProxy为JDK动态代理,调用MybatisMapperMethod方法的execute方法。

    3、MybatisMapperMethod的execute执行逻辑为,调用SqlSessionTemplate的selectOne方法,其内部通过调用sqlSessionProxy来代理执行selectOne方法。 代理类为SqlSessionInterceptor。

    4、代理类的执行逻辑为:通过SqlSessionFactory创建SqlSession(DefaultSqlSession),然后调用对应的selectOne方法,最后commit SqlSession并返回执行结果。

  • 相关阅读:
    File操作
    集合
    几个python资料地址
    Case1-用list写shoppingcart
    字符串操作
    运算-Dictionary
    运算-list
    Python数据类型
    标准库和库导入
    Pycharm
  • 原文地址:https://www.cnblogs.com/malcolmfeng/p/16005357.html
Copyright © 2020-2023  润新知