中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Mybatis?SqlSession怎么創建

發布時間:2023-04-17 15:34:01 來源:億速云 閱讀:122 作者:iii 欄目:開發技術

這篇文章主要介紹了Mybatis SqlSession怎么創建的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇Mybatis SqlSession怎么創建文章都會有所收獲,下面我們一起來看看吧。

前言

先上案例代碼,我們按照這個案例一步一步的搞定Mybatis源碼。

public class MybatisApplication {
    public static final String URL = "jdbc:mysql://localhost:3306/mblog";
    public static final String USER = "root";
    public static final String PASSWORD = "123456";

    public static void main(String[] args) {
        String resource = "mybatis-config.xml";
        InputStream inputStream = null;
        SqlSession sqlSession = null;
        try {
            inputStream = Resources.getResourceAsStream(resource);
            SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
            sqlSession = sqlSessionFactory.openSession();
            UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
            System.out.println(userMapper.selectById(1));

        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            try {
                inputStream.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
            sqlSession.close();
        }
    }
}

前面我們已經講了Mybatis是如何解析相關配置文件的,如果怕迷路,還是建議先看前一篇文章:

Mybatis是如何解析配置文件的?看完終于明白了

繼續開擼~~

SqlSession sqlSession = sqlSessionFactory.openSession();

前面那篇文章已經分析了,這里的sqlSessionFactory其實就是DefaultSqlSessionFactory。

所以這里,我們就從DefaultSqlSessionFactory里的openSession方法開始。

public class DefaultSqlSessionFactory implements SqlSessionFactory {

  private final Configuration configuration;

  public DefaultSqlSessionFactory(Configuration configuration) {
    this.configuration = configuration;
  }
  //創建session,這個方法直接調用本類中的另外一個方法
  @Override
  public SqlSession openSession() {
    return openSessionFromDataSource(configuration.getDefaultExecutorType(), null, false);
  }
  //其實是調用這個方法
  private SqlSession openSessionFromDataSource(ExecutorType execType, TransactionIsolationLevel level, boolean autoCommit) {
    Transaction tx = null;
    try {
      //對應xml標簽<environments> ,這個在配置文件解析的時候就已經存放到configuration中了。
      final Environment environment = configuration.getEnvironment();
      final TransactionFactory transactionFactory = getTransactionFactoryFromEnvironment(environment);
      tx = transactionFactory.newTransaction(environment.getDataSource(), level, autoCommit);
      //創建一個executor來執行SQL  
      final Executor executor = configuration.newExecutor(tx, execType);
      //這里也說明了,為什么我們代碼里的SqlSession是DefaultSqlSession
      return new DefaultSqlSession(configuration, executor, autoCommit);
    } catch (Exception e) {
      closeTransaction(tx); // may have fetched a connection so lets call close()
      throw ExceptionFactory.wrapException("Error opening session.  Cause: " + e, e);
    } finally {
      ErrorContext.instance().reset();
    }
  }

    private TransactionFactory getTransactionFactoryFromEnvironment(Environment environment) {
        if (environment == null || environment.getTransactionFactory() == null) {
            return new ManagedTransactionFactory();
        }
        return environment.getTransactionFactory();
    }
}

這個方法中的主要內容有:

Mybatis?SqlSession怎么創建

下面我們就來逐個攻破。

創建事務Transaction

事務工廠類型可以配置為JDBC類型或者MANAGED類型。

Mybatis?SqlSession怎么創建

JdbcTransactionFactory生產JdbcTransaction。

ManagedTransactionFactory生產ManagedTransaction。

如果配置的JDBC,則會使用Connection對象的commit()、rollback()、close()方法來管理事務。

如果我們配置的是MANAGED,會把事務交給容器來管理,比如JBOSS,Weblogic。因為我們是本地跑的程序,如果配置成MANAGED就會不有任何事務。

但是,如果我們項目中是Spring集成Mybatis,則沒有必要配置事務,因為我們會直接在applicationContext.xml里配置數據源和事務管理器,從而覆蓋Mybatis的配置。

創建執行器Executor

調用configuration的newExecutor方法創建Executor。

final Executor executor = configuration.newExecutor(tx, execType);
//Configuration中
public Executor newExecutor(Transaction transaction, ExecutorType executorType) {
    executorType = executorType == null ? defaultExecutorType : executorType;
    executorType = executorType == null ? ExecutorType.SIMPLE : executorType;
    Executor executor;
    //第一步
    if (ExecutorType.BATCH == executorType) {
      executor = new BatchExecutor(this, transaction);
    } else if (ExecutorType.REUSE == executorType) {
      executor = new ReuseExecutor(this, transaction);
    } else {
      executor = new SimpleExecutor(this, transaction);
    }
    //第二步
    if (cacheEnabled) {
      executor = new CachingExecutor(executor);
    }
    //第三步
    executor = (Executor) interceptorChain.pluginAll(executor);
    return executor;
}

此方法分三個步驟。

第一步:創建執行器

Executor的基本類型有三種:

public enum ExecutorType {
  SIMPLE, REUSE, BATCH
}

SIMPLE為默認類型。

Mybatis?SqlSession怎么創建

為什么要讓抽象類BaseExecutor實現Executor接口,然后讓具體實現類繼承抽象類呢?

這就是模板方法模式的實現。

模板方法模式就是定義一個算法骨架,并允許子類為一個或者多個步驟提供實現。模板方法是得子類可以再不改變算法結構的情況下,重新定義算法的某些步驟。

關于模板方法模式推薦閱讀:

快速掌握模板方法模式

抽象方法是在子類匯總實現的,每種執行器自己實現自己的邏輯,BaseExecutor最終會調用到具體的子類中。

抽象方法

protected abstract int doUpdate(MappedStatement ms, Object parameter) throws SQLException;

protected abstract List<BatchResult> doFlushStatements(boolean isRollback) throws SQLException;

protected abstract <E> List<E> doQuery(MappedStatement ms, Object parameter, RowBounds rowBounds, ResultHandler resultHandler, BoundSql boundSql) throws SQLException;

protected abstract <E> Cursor<E> doQueryCursor(MappedStatement ms, Object parameter, RowBounds rowBounds, BoundSql boundSql)  throws SQLException;

第二步:緩存裝飾

在上面代碼中的第二步

if (cacheEnabled) {
      executor = new CachingExecutor(executor);
}

如果cacheEnabled=true,會用裝飾器設計模式對Executor進行裝飾。

第三步:插件代理

緩存裝飾完后,就會執行

executor = (Executor) interceptorChain.pluginAll(executor);

這里會對 Executor 植入插件邏輯。

比如:分頁插件中就需要把插件植入的Executor

Mybatis?SqlSession怎么創建

好了,到此,執行器創建的就搞定了。

創建DefaultSqlSession對象

把前面解析配置文件創建的Configuration對象和創建的執行器Executor賦給DefaultSqlSession中的屬性。

public DefaultSqlSession(Configuration configuration, Executor executor, boolean autoCommit) {
  this.configuration = configuration;
  this.executor = executor;
  this.dirty = false;
  this.autoCommit = autoCommit;
}

關于“Mybatis SqlSession怎么創建”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“Mybatis SqlSession怎么創建”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

武强县| 福鼎市| 永定县| 方城县| 托克逊县| 中宁县| 金山区| 友谊县| 大城县| 新巴尔虎左旗| 天气| 洪湖市| 资讯| 高州市| 龙州县| 南宁市| 武平县| 五峰| 通化市| 勃利县| 井陉县| 隆尧县| 澄江县| 铁力市| 亳州市| 高密市| 红桥区| 徐闻县| 吴堡县| 黄陵县| 封开县| 河源市| 东丰县| 正定县| 锦州市| 万山特区| 丰原市| 德令哈市| 阳原县| 芮城县| 体育|