SqlSession 接口提供數(shù)據(jù)庫執(zhí)行的所有方法(增刪改查、提交寓落、回滾等)市怎,在這里我們重點討論其實現(xiàn)類 DefaultSqlSession糠排。
對于數(shù)據(jù)庫操作的具體實現(xiàn)為下圖紅框標出的五個方法,其余方法皆調(diào)用這五個方法來實現(xiàn):
例如蠢壹,該類中所有的 selectOne 方法嗓违、selectMap 方法和其他的 selectList 均調(diào)用 selectList(java.lang.String, java.lang.Object, org.apache.ibatis.session.RowBounds) 實現(xiàn);所有的 insert图贸、delete 及其余 update 均調(diào)用
update(java.lang.String, java.lang.Object) 實現(xiàn)蹂季,具體可查看源碼。
這種處理方式值得我們在實際開發(fā)中借鑒:通過改變參數(shù)傳遞調(diào)用已有方法疏日,使代碼脈絡清晰偿洁,從而以達到簡化代碼的目的。
另外需要注意的是兩個成員變量: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 將數(shù)據(jù)庫執(zhí)行的具體操作委托給了 Executor 來實現(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();
}
}
附:
當前版本:mybatis-3.5.0
官網(wǎng)文檔:MyBatis
項目實踐:MyBatis Learn
手寫源碼:MyBatis 簡易實現(xiàn)