1. mybatis有三种基本的Executor执行器:
1.1 SimpleExecutor 每执行一次update或select,就开启一个Statement对象,用完立刻关闭Statement对象。
1.2 PauseExecutor 执行update或select,以sql做为key查找Statement对象,存在就使用,不存在就创建,用完后,不关闭Statement对象,而且放置于Map内,供下一次使用。简言之,就是重复使用Statement对象。
1.3 BatchExecutor 执行update,将所有sql通过addBatch()都添加到批处理中,等待统一执行executeBatch(),它缓存了多个Statement对象,每个Statement对象都是addBatch()完毕后,等待逐一执行executeBatch()批处理。与JDBC批处理相同。
2. 作用范围 Executor的这些特点,都严格限制在SqlSession生命周期范围内。
3. Mybatis中如何指定使用哪一种Executor执行器? 在mybatis的配置文件中,可以指定默认的ExecutorType执行器类型,也可以手动给DefaultSqlSessionFactory的创建SqlSession的方法传递ExecutorType类型参数。