SqlSession 接口提供數據庫執行的所有方法(增刪改查、提交、回滾等),在這里我們重點討論其實現類 DefaultSqlSession。
對于數據庫操作的具體實現為下圖紅框標出的五個方法,其余方法皆調用這五個方法來實現:
DefaultSqlSession Structure
例如,該類中所有的 selectOne 方法、selectMap 方法和其他的 selectList 均調用 selectList(java.lang.String, java.lang.Object, org.apache.ibatis.session.RowBounds) 實現;所有的 insert、delete 及其余 update 均調用
update(java.lang.String, java.lang.Object) 實現,具體可查看源碼。
這種處理方式值得我們在實際開發中借鑒:通過改變參數傳遞調用已有方法,使代碼脈絡清晰,從而以達到簡化代碼的目的。
另外需要注意的是兩個成員變量: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 負責獲取配置信息,如 Mapper 接口、映射語句、ObjectFactory、ObjectWrapperFactory、ReflectorFactory 等。如:
@Override
public <T> T getMapper(Class<T> type) {
return configuration.<T>getMapper(type, this);
}
- SqlSession 將數據庫執行的具體操作委托給了 Executor 來實現,如 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();
}
}
附:
當前版本:mybatis-3.5.0
官網文檔:MyBatis
項目實踐:MyBatis Learn
手寫源碼:MyBatis 簡易實現