SqlSession 接口提供數(shù)據(jù)庫(kù)執(zhí)行的所有方法(增刪改查、提交、回滾等),在這里我們重點(diǎn)討論其實(shí)現(xiàn)類 DefaultSqlSession。
對(duì)于數(shù)據(jù)庫(kù)操作的具體實(shí)現(xiàn)為下圖紅框標(biāo)出的五個(gè)方法,其余方法皆調(diào)用這五個(gè)方法來(lái)實(shí)現(xiàn):

DefaultSqlSession Structure
例如,該類中所有的 selectOne 方法、selectMap 方法和其他的 selectList 均調(diào)用 selectList(java.lang.String, java.lang.Object, org.apache.ibatis.session.RowBounds) 實(shí)現(xiàn);所有的 insert、delete 及其余 update 均調(diào)用
update(java.lang.String, java.lang.Object) 實(shí)現(xiàn),具體可查看源碼。
這種處理方式值得我們?cè)趯?shí)際開發(fā)中借鑒:通過(guò)改變參數(shù)傳遞調(diào)用已有方法,使代碼脈絡(luò)清晰,從而以達(dá)到簡(jiǎn)化代碼的目的。
另外需要注意的是兩個(gè)成員變量:configuration 和 executor。
private final Configuration configuration;
private final Executor executor;
public DefaultSqlSession(Configuration configuration, Executor executor, boolean autoCommit) {
this.configuration = configuration;
this.executor = executor;
this.dirty = false;
this.autoCommit = autoCommit;
}
- configuration 負(fù)責(zé)獲取配置信息,如 Mapper 接口、映射語(yǔ)句、ObjectFactory、ObjectWrapperFactory、ReflectorFactory 等。如:
@Override
public <T> T getMapper(Class<T> type) {
return configuration.<T>getMapper(type, this);
}
- SqlSession 將數(shù)據(jù)庫(kù)執(zhí)行的具體操作委托給了 Executor 來(lái)實(shí)現(xiàn),如 selectList 方法:
@Override
public <E> List<E> selectList(String statement, Object parameter, RowBounds rowBounds) {
try {
MappedStatement ms = configuration.getMappedStatement(statement);
return executor.query(ms, wrapCollection(parameter), rowBounds, Executor.NO_RESULT_HANDLER);
} catch (Exception e) {
throw ExceptionFactory.wrapException("Error querying database. Cause: " + e, e);
} finally {
ErrorContext.instance().reset();
}
}
附:
當(dāng)前版本:mybatis-3.5.0
官網(wǎng)文檔:MyBatis
項(xiàng)目實(shí)踐:MyBatis Learn
手寫源碼:MyBatis 簡(jiǎn)易實(shí)現(xiàn)