MyBatis源码浅析(一)开篇

作者:李新杰 时间:2022-09-28 03:28:24 

源码学习的好处不用多说,Mybatis源码量少、逻辑简单,将写个系列文章来学习。

SqlSession

Mybatis的使用入口位于org.apache.ibatis.session包中的SqlSession,发现它是个接口,必然有个默认实现类org.apache.ibatis.session.defaults包中的DefaultSqlSession。我们从来没有new过这个类,按照Java惯例使用SqlSessionFactory里的工厂方法。发现它也是个接口,必然有默认实现类DefaultSqlSessionFactory。该类依然不用自己创建,使用SqlSessionFactoryBuilder里的工厂方法。

DefaultSqlSession

DefaultSqlSession里主要方法:

1)Cursor<T> selectCursor(String statement, Object parameter, RowBounds rowBounds),委托给executor.queryCursor(ms, wrapCollection(parameter), rowBounds)。

2)List<E> selectList(String statement, Object parameter, RowBounds rowBounds)和void select(String statement, Object parameter, RowBounds rowBounds, ResultHandler handler),委托给executor.query(ms, wrapCollection(parameter), rowBounds, handler)。

3)int update(String statement, Object parameter),委托给executor.update(ms, wrapCollection(parameter))。
可见,最终都有executor来完成。

Executor

Executor位于org.apache.ibatis.executor包中,是个接口,实现类是BaseExecutor和CachingExecutor。其中BaseExecutor是抽象的,有三个子类SimpleExecutor、ReuseExecutor和BatchExecutor,见名知意。BaseExecutor里主要方法:

1)List<E> query(MappedStatement ms, Object parameter, RowBounds rowBounds, ResultHandler resultHandler, CacheKey key, BoundSql boundSql)和List<E> queryFromDatabase(MappedStatement ms, Object parameter, RowBounds rowBounds, ResultHandler resultHandler, CacheKey key, BoundSql boundSql),委托为抽象的abstract <E> List<E> doQuery(MappedStatement ms, Object parameter, RowBounds rowBounds, ResultHandler resultHandler, BoundSql boundSql)。

2)Cursor<E> queryCursor(MappedStatement ms, Object parameter, RowBounds rowBounds),委托给抽象的abstract <E> Cursor<E> doQueryCursor(MappedStatement ms, Object parameter, RowBounds rowBounds, BoundSql boundSql)。

3)int update(MappedStatement ms, Object parameter),委托给抽象的abstract int doUpdate(MappedStatement ms, Object parameter)。

基类处理公共部分,具体留给子类实现。

再看下SimpleExecutor里的主要方法:

1)List<E> doQuery(MappedStatement ms, Object parameter, RowBounds rowBounds, ResultHandler resultHandler, BoundSql boundSql),委托给handler.<E>query(stmt, resultHandler)。

2)Cursor<E> doQueryCursor(MappedStatement ms, Object parameter, RowBounds rowBounds, BoundSql boundSql),委托给handler.<E>queryCursor(stmt)。

3)int doUpdate(MappedStatement ms, Object parameter),委托给handler.update(stmt)。

可见,最终由handler来处理。

StatementHandler

StatementHandler位于org.apache.ibatis.executor.statement包中,是个接口,实现类是BaseStatementHandler和RoutingStatementHandler。BaseStatementHandler是抽象的,有三个子类SimpleStatementHandler、PreparedStatementHandler和CallableStatementHandler。这三个应该比较熟悉,分别处理不带参数的sql语句、参数化sql语句和存储过程。再看SimpleStatementHandler里的主要方法:

1)List<E> query(Statement statement, ResultHandler resultHandler),委托给statement.execute(sql)。

2)Cursor<E> queryCursor(Statement statement),委托给statement.execute(sql)。

3)int update(Statement statement),委托给statement.execute(sql)。

最终由statement执行sql。这就回到了java.sql包了。

Mybatis主要完成对sql参数的封装处理、结果集的获取并生成对象,而把sql语句的构建过程留给用户。Mybatis的作者故意这样设计的。虽然框架从整体来看是半自动的,但灵活性却得到了极大增加。

来源:http://www.cnblogs.com/lixinjie/archive/2016/11/10/mybatis-src-01-beginning.html

标签:mybatis,源码
0
投稿

猜你喜欢

  • Spring security权限配置与使用大全

    2022-03-05 15:37:21
  • Java中闭包简单代码示例

    2023-11-08 23:09:48
  • Android四大组件之Service详解

    2023-10-16 14:22:38
  • java程序员必须要学会的linux命令总结(推荐)

    2021-12-11 00:47:47
  • Android互联网访问图片并在客户端显示的方法

    2021-12-26 21:25:10
  • Android百度地图实现搜索和定位及自定义图标绘制并点击时弹出泡泡

    2023-08-30 21:30:38
  • 深入探索Java常量池

    2022-12-28 00:55:53
  • 详解C语言内核字符串拷贝与比较

    2023-11-02 15:22:30
  • C# FileStream实现多线程断点续传

    2022-06-19 06:50:56
  • Ribbon单独使用,配置自动重试,实现负载均衡和高可用方式

    2023-05-12 00:49:15
  • SpringBoot如何读取war包jar包和Resource资源

    2023-11-09 01:40:44
  • Gradle快速安装及入门

    2021-11-25 09:33:28
  • Spring框架应用的权限控制系统详解

    2023-11-11 14:17:11
  • Redis之GEO存储地理位置信息的使用

    2023-12-22 14:29:49
  • C#中的数组用法详解

    2021-08-19 14:50:17
  • Mybatis中注解@MapKey的使用详解

    2023-11-24 21:43:35
  • C#邮件定时群发工具Atilia用法实例

    2022-06-13 11:50:24
  • Java concurrency线程池之线程池原理(二)_动力节点Java学院整理

    2023-11-28 23:43:18
  • Maven本地打包war包实现代码解析

    2021-09-06 12:51:14
  • 为IObservable实现自己的运算符(详解)

    2022-04-02 08:58:15
  • asp之家 软件编程 m.aspxhome.com