mybatis SqlSessionFactory工廠模式

1、工廠方法模式實現sqlsession

(從別人博客複製的圖)sql

 1.Sqlsession接口

在sqlsession接口中包含了全部可能執行的sql語句。而Defaultsqlsession是他的實現類,實現了其中的方法。session

 

 1 public interface SqlSession extends Closeable {
 2 
 3   /**
 4    * Retrieve a single row mapped from the statement key
 5    * @param <T> the returned object type
 6    * @param statement
 7    * @return Mapped object
 8    */
 9   <T> T selectOne(String statement);
10 /**
11    * Retrieve a list of mapped objects from the statement key and parameter.
12    * @param <E> the returned list element type
13    * @param statement Unique identifier matching the statement to use.
14    * @return List of mapped object
15    */
16   <E> List<E> selectList(String statement);

 

 

 

 

2.DefaultSqlSession

 1 public class DefaultSqlSession implements SqlSession {
 2 
 3   private Configuration configuration;
 4   private Executor executor;
 5 
 6   private boolean dirty;
 7 
 8  public <E> List<E> selectList(String statement, Object parameter, RowBounds rowBounds) {
 9     try {
10       MappedStatement ms = configuration.getMappedStatement(statement);
11       List<E> result = executor.query(ms, wrapCollection(parameter), rowBounds, Executor.NO_RESULT_HANDLER);
12       return result;
13     } catch (Exception e) {
14       throw ExceptionFactory.wrapException("Error querying database.  Cause: " + e, e);
15     } finally {
16       ErrorContext.instance().reset();
17     }
18   }

3.SqlSessionFactory接口

sqlsessionfactory類中有opsession方法,用來建立sqlsession。app

四、DefaultSqlSessionFactory類實現了SqlSessionFactory

相關文章
相關標籤/搜索