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)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Spring Cloud Alibaba 本地調(diào)試介紹及方案設計
為了解決 本地調(diào)試 的問題,本文實現(xiàn)了一種簡單實用的策略,可以通過 Nacos 動態(tài)配置服務路由,還可以基于用戶,部門,組織等級別配置服務路由,實現(xiàn) 本地調(diào)試 的同時,實際上也實現(xiàn) 灰度發(fā)布,感興趣的朋友跟隨小編一起看看吧2021-07-07Shiro + JWT + SpringBoot應用示例代碼詳解
這篇文章主要介紹了Shiro (Shiro + JWT + SpringBoot應用),本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-06-06SpringBoot集成pf4j實現(xiàn)插件開發(fā)功能的代碼示例
pf4j是一個插件框架,用于實現(xiàn)插件的動態(tài)加載,支持的插件格式(zip、jar),本文給大家介紹了SpringBoot集成pf4j實現(xiàn)插件開發(fā)功能的示例,文中通過代碼示例給大家講解的非常詳細,需要的朋友可以參考下2024-07-07spring和quartz整合,并簡單調(diào)用(實例講解)
下面小編就為大家?guī)硪黄猻pring和quartz整合,并簡單調(diào)用(實例講解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-07-07