欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mybatis?連接mysql數(shù)據(jù)庫底層運行的原理分析

 更新時間:2022年03月11日 11:08:51   作者:TNT_D  
這篇文章主要介紹了Mybatis?連接mysql數(shù)據(jù)庫底層運行的原理分析,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

工作中一直在用spring+springmvc+mybatis,只是知道它是用于持久層框架,但是一直不知道原理是什么,通過網(wǎng)上視頻解釋,自己做一個筆記,方便以后查閱。

什么是mybatis

MyBatis 是一款優(yōu)秀的持久層框架,它支持定制化 SQL、存儲過程以及高級映射。

MyBatis 避免了幾乎所有的 JDBC 代碼和手動設置參數(shù)以及獲取結(jié)果集。

MyBatis 可以使用簡單的 XML 或注解來配置和映射原生信息,將接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java對象)映射成數(shù)據(jù)庫中的記錄。

首先拆解mybatis架構(gòu)

我將mybatis主要拆分成三個部分

  • 數(shù)據(jù)源:如何獲取mysql的數(shù)據(jù)庫地址。
  • 執(zhí)行語句:如何將我們在mybatis配置文件中生成的sql語句映射到mysql中。
  • 操作者:連接mysql數(shù)據(jù)庫,執(zhí)行sql語句,得到sql語句的查詢結(jié)果。好比打開mysql圖形化工具,Navicat for MySQL,首先連接到需要的數(shù)據(jù)庫,編寫sql語句,執(zhí)行語句,并得到結(jié)果。

在mybatis官網(wǎng)上找的入門代碼

// 獲取數(shù)據(jù)源
String resource = "org/mybatis/example/mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
// 獲取執(zhí)行語句
DataSource dataSource = BlogDataSourceFactory.getBlogDataSource();
TransactionFactory transactionFactory = new JdbcTransactionFactory();
Environment environment = new Environment("development", transactionFactory, dataSource);
Configuration configuration = new Configuration(environment);
configuration.addMapper(BlogMapper.class);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(configuration);
// 執(zhí)行sql并得到返回結(jié)果
SqlSession session = sqlSessionFactory.openSession();
try {
  Blog blog = (Blog) session.selectOne("org.mybatis.example.BlogMapper.selectBlog", 101);
} finally {
  session.close();
}

第一點、數(shù)據(jù)源的獲取

第二點、獲取執(zhí)行語句

在獲取sql語句的時候,最主要的類的就是mapperstatement。

第三點、操作數(shù)據(jù)源

在操作數(shù)據(jù)庫的時候,其實底層封裝還是java.sql中的JDBC操作,核心類還是會用到mapperstatement。

mybatis加載mapper文件有4中方式,分別是:

<!-- 使用相對于類路徑的資源引用 -->
<mappers>
? <mapper resource="org/mybatis/builder/AuthorMapper.xml"/>
? <mapper resource="org/mybatis/builder/BlogMapper.xml"/>
? <mapper resource="org/mybatis/builder/PostMapper.xml"/>
</mappers>
<!-- 使用完全限定資源定位符(URL) -->
<mappers>
? <mapper url="file:///var/mappers/AuthorMapper.xml"/>
? <mapper url="file:///var/mappers/BlogMapper.xml"/>
? <mapper url="file:///var/mappers/PostMapper.xml"/>
</mappers>
<!-- 使用映射器接口實現(xiàn)類的完全限定類名 -->
<mappers>
? <mapper class="org.mybatis.builder.AuthorMapper"/>
? <mapper class="org.mybatis.builder.BlogMapper"/>
? <mapper class="org.mybatis.builder.PostMapper"/>
</mappers>
<!-- 將包內(nèi)的映射器接口實現(xiàn)全部注冊為映射器 -->
<mappers>
? <package name="org.mybatis.builder"/>
</mappers>

其中優(yōu)先級最高的是package方式。 

mybatis的執(zhí)行器有3中,默認的是simple。 

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • 初次使用IDEA創(chuàng)建maven項目的教程

    初次使用IDEA創(chuàng)建maven項目的教程

    這篇文章主要介紹了初次使用IDEA創(chuàng)建maven項目的教程講解,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2018-01-01
  • Spring Cloud Alibaba 本地調(diào)試介紹及方案設計

    Spring Cloud Alibaba 本地調(diào)試介紹及方案設計

    為了解決 本地調(diào)試 的問題,本文實現(xiàn)了一種簡單實用的策略,可以通過 Nacos 動態(tài)配置服務路由,還可以基于用戶,部門,組織等級別配置服務路由,實現(xiàn) 本地調(diào)試 的同時,實際上也實現(xiàn) 灰度發(fā)布,感興趣的朋友跟隨小編一起看看吧
    2021-07-07
  • Shiro + JWT + SpringBoot應用示例代碼詳解

    Shiro + JWT + SpringBoot應用示例代碼詳解

    這篇文章主要介紹了Shiro (Shiro + JWT + SpringBoot應用),本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-06-06
  • spring緩存自定義resolver的方法

    spring緩存自定義resolver的方法

    這篇文章主要為大家詳細介紹了spring緩存自定義resolver的方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • SpringBoot集成pf4j實現(xiàn)插件開發(fā)功能的代碼示例

    SpringBoot集成pf4j實現(xiàn)插件開發(fā)功能的代碼示例

    pf4j是一個插件框架,用于實現(xiàn)插件的動態(tài)加載,支持的插件格式(zip、jar),本文給大家介紹了SpringBoot集成pf4j實現(xiàn)插件開發(fā)功能的示例,文中通過代碼示例給大家講解的非常詳細,需要的朋友可以參考下
    2024-07-07
  • spring和quartz整合,并簡單調(diào)用(實例講解)

    spring和quartz整合,并簡單調(diào)用(實例講解)

    下面小編就為大家?guī)硪黄猻pring和quartz整合,并簡單調(diào)用(實例講解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • 微信支付java版本之獲取Access_token

    微信支付java版本之獲取Access_token

    這篇文章主要介紹了微信支付java版本之獲取Access_token,java如何獲取Access_token,感興趣的小伙伴們可以參考一下
    2016-08-08
  • Java中clone方法使用筆記

    Java中clone方法使用筆記

    clone顧名思義是復制,在Java語言中,clone方法被對象調(diào)用,所以會復制對象,下面這篇文章主要給大家介紹了關于Java中clone方法使用的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-02-02
  • Java swing 圖像處理多種效果實現(xiàn)教程

    Java swing 圖像處理多種效果實現(xiàn)教程

    這篇文章主要介紹了Java swing 圖像處理多種效果實現(xiàn)教程,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • spring集成redis cluster詳解

    spring集成redis cluster詳解

    這篇文章主要介紹了spring集成redis cluster詳解,分享了maven依賴,Spring配置,增加connect-redis.properties 配置文件等相關內(nèi)容,具有一定參考價值,需要的朋友可以了解下。
    2017-11-11

最新評論