Mybatis有三种基本的Executor执行器,SimpleExecutor、ReuseExecutor、 BatchExecutor。

SimpleExecutor:每执行一次update或select,就开启一个Statement对象,用完立刻关闭 Statement对象。

ReuseExecutor:执行update或select,以sql作为key查找Statement对象,存在就使用, 不存在就创建,用完后,不关闭Statement对象,而是放置于Map<String, Statement>内, 供下一次使用。简言之,就是重复使用Statement对象。

BatchExecutor:执行update(没有select,JDBC批处理不支持select),将所有sql都添加 到批处理中(addBatch()),等待统一执行(executeBatch()),它缓存了多个Statement 对象,每个Statement对象都是addBatch()完毕后,等待逐一执行executeBatch()批处理。 与JDBC批处理相同。

作用范围:Executor的这些特点,都严格限制在SqlSession生命周期范围内。