日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

Mybatis框架中SqlSessionFactory

發布時間:2023/12/10 46 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Mybatis框架中SqlSessionFactory 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

首先SqlSessionFactory與SqlSession都是同一個接口

SqlSessionFactory是通過SqlSessionFactoryBuilder的build方法創建的

而build方法創建的是一個SqlSessionFactory的實現類,叫DefaultSqlSessionFactory

然后這個實現類主要用的設計模式是建造者(build)模式,而里面最終要達到的一個目的是為了創建出DefaultSqlSession,這個是SqlSession的實現類.

前面說了SqlSession也是同一個接口,那么SqlSession=SqlSessionFactory.openSession()就相當于SqlSession=DefaultSqlSession這個實現類.

那么這個實現類是干什么的呢?這個實現類可以進行增刪查改以及事務操作等.

那么DefaultSqlSession是怎么進行這些操作的呢?答:通過調用Executor執行器.

所以,咱們平時見到的SqlSession.select()等等其實是在操作DefaultSqlSession.select()的方法,而DefaultSqlSession的方法其實也不是就能夠實現對數據庫進行操作的,而是通過調用Executor執行器來執行

而Executor執行器其實也是一個接口,而在解析配置文件的時候已經解析出來SQL,那么根據一路傳過來的SQL以及參數等信息,Executor再調度StatementHandler等對象對數據庫進行增刪查改操作.

總結:現在你應該明白了吧,其實我們看到的都是表面,你認為的SqlSession能進行數據庫操作其實不是的,是它的實現類再調用底層的Executor,底層的Executor再調度相關數據庫操作對象才搞定的,

?

SqlSessionFactory是MyBatis的關鍵對象,它是個單個數據庫映射關系經過編譯后的內存鏡像.SqlSessionFactory對象的實例可以通過SqlSessionFactoryBuilder對象類獲得,而SqlSessionFactoryBuilder則可以從XML配置文件或一個預先定制的Configuration的實例構建出SqlSessionFactory的實例.每一個MyBatis的應用程序都以一個SqlSessionFactory對象的實例為核心.同時SqlSessionFactory也是線程安全的,SqlSessionFactory一旦被創建,應該在應用執行期間都存在.在應用運行期間不要重復創建多次,建議使用單例模式.SqlSessionFactory是創建SqlSession的工廠.

//SqlSessionFactory接口源碼如下所示:package org.apache.ibatis.session;import java.sql.Connection;public interface SqlSessionFactory {SqlSession openSession();//這個方法最經常用,用來創建SqlSession對象.SqlSession openSession(boolean autoCommit);SqlSession openSession(Connection connection);SqlSession openSession(TransactionIsolationLevel level);SqlSession openSession(ExecutorType execType);SqlSession openSession(ExecutorType execType, boolean autoCommit);SqlSession openSession(ExecutorType execType, TransactionIsolationLevel level);SqlSession openSession(ExecutorType execType, Connection connection);Configuration getConfiguration();}

?

總結

以上是生活随笔為你收集整理的Mybatis框架中SqlSessionFactory的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。