導航:首頁 > 源碼編譯 > mybatis語句源碼

mybatis語句源碼

發布時間:2022-12-12 20:16:39

⑴ Mybatis源碼解析(1) 如何獲得SQL語句

筆者只能說會使用Mybtis,並沒有具體研究過源碼,站在一個使用者的角度記錄解決的問題。
跳過大部分源碼,從一個功能點開始入手。

以 Select 操作為例,研究如何獲取經過 Mybatis 中 動態語句 轉換後的的 SQL語句
我們這里不涉及復雜的過程原理(如:讀取配置文件、Mapper代理等( 我也不懂 )),只說明一下具體流程。

發現studentMapper被MapperProxy實現。

好奇的同學肯定會問studentMapper是如何創建MapperProxy實例的呢?

一路跟隨瞎點。會發現一個配置類,裡面東西很多,目前只看和Mapper有關系。

我們繼續下一步

到此關於Mapper的運行過程已經分析完了,下面繼續分析SelectOne過程。

selectOne 其實只是 selectList 取第一個元素(這點是沒有想到的)。

源碼解析,這還是第一次寫這類文章,確實這些框架的原理,並沒有研究過只是知道一點概念,Mapper動態代理之類的。網上的博客從大方向出發,框架設計、設計模式之類的,對於我這種基礎薄弱的人看的雲里霧里。我准備從一個一個功能開始初步了解、研究此類框架原理。
參考 https://blog.csdn.net/luanlouis/article/details/40422941

⑵ Mybatis源碼分析

上面這兩幅圖來源於網路,不過畫的很好,基本說明了Mybatis的架構流程。

說明:

Executor

MyBatis執行器,是MyBatis 調度的核心,負責SQL語句的生成和查詢緩存的維護

StatementHandler

封裝了JDBC Statement操作,負責對JDBC statement 的操作,如設置參數、將Statement結果集轉換成List集合。

ParameterHandler

負責對用戶傳遞的參數轉換成JDBC Statement 所需要的參數

ResultSetHandler

負責將JDBC返回的ResultSet結果集對象轉換成List類型的集合

TypeHandler

負責java數據類型和jdbc數據類型之間的映射和轉換

SqlSource

負責根據用戶傳遞的parameterObject,動態地生成SQL語句,將信息封裝到BoundSql對象中,並返回BoundSql表示動態生成的SQL語句以及相應的參數信息

基本上Mybatis的流程就是這樣了,其中還有很多實現細節暫時看不太懂。 我認為學習框架源碼分為兩步:

目前第一步尚有問題,需要多走幾遍源碼,加深下理解,一起加油~~

⑶ MyBatis源碼解讀 - 使用MyBatis操作資料庫

本篇文章主要介紹了使用MyBatis框架完成資料庫的增、刪、改、查操作。

准備工作

運行schema.sql和data.sql腳本文件中的 SQL 語句創建t_user表並添加部分測試數據。

schema.sql:

data.sql:

使用MyBatis框架操作資料庫步驟:

(1)定義Java實體

User.java

(2)定義Mapper介面

UserDao.java

(3)編寫XML映射文件

UserDao.xml

(4)編寫MyBatis主配置文件

MyBatis使用 XML 文件格式描述配置信息,內容如下:

(5)編寫測試類

Demo.java

輸出結果:

⑷ MyBatis­Plus快速入門源碼筆記共享,拿走吧你

為什麼要學習它呢?

答:MyBatisPlus可以節省我們大量工作時間,所有的CRUD代碼它都可以自動化完成!

優點:
1. 易於上手和掌握。
2. sql寫在xml里,便於統一管理和優化。
3. 解除sql與程序代碼的耦合。
4. 提供映射標簽,支持對象與資料庫的orm欄位關系映射
5. 提供對象關系映射標簽,支持對象關系組建維護
6. 提供xml標簽,支持編寫動態sql。

MyBatis Plus(簡稱 MP)是一個 MyBatis的增強工具,在 MyBatis 的基礎上只做增強不做改變,為簡化開發、提高效率而生。

就像 魂斗羅 中的 1P、2P,基友搭配,效率翻倍。

特性:

無侵入 :只做增強不做改變,引入它不會對現有工程產生影響,如絲般順滑。

損耗小 :啟動即會自動注入基本 CURD,性能基本無損耗,直接面向對象操作 強大的 CRUD 操作 :內置通用 Mapper、通用 Service,僅僅通過少量配置即可實現單表大部分 CRUD 操作,更有強大的條件構造器,滿足各類使用需求 支持 Lambda 形式調用 :通過 Lambda 表達式,方便地編寫各類查詢條件,無需再擔心欄位寫錯。

支持組件自動生成 :支持多達 4 種主鍵策略(內含分布式唯一 ID 生成器 Sequence),可自由配置,完美解決主鍵問題。

支持 ActiveRecord 模式 :支持 ActiveRecord 形式調用,實體類只需繼承 Model 類即可進行強大的 CRUD 操作。

支持自定義全局通用操作 :支持全局通用方法注入( Write once, use anywhere )。

內置代碼生成器 :採用代碼或者 Maven 插件可快速生成 Mapper 、 Model 、 Service 、 Controller 層代碼,支持模板引擎,更有超多自定義配置等您來使用 內置分頁插件 :基於 MyBatis 物理分頁,開發者無需關心具體操作,配置好插件之後,寫分頁等同於普通 List查詢。

分頁插件支持多種資料庫 :支持 MySQL、MariaDB、Oracle、DB2、H2、HSQL、SQLite、Postgre、SQLServer 等多種資料庫。

內置性能分析插件 :可輸出 Sql 語句以及其執行時間,建議開發測試時啟用該功能,能快速揪出慢查詢。

內置全局攔截插件 :提供全表 delete 、 update 操作智能分析阻斷,也可自定義攔截規則,預防誤操作。

1.1 、引入mybatis-plus相關maven依賴


引入mybatis-plus在spring boot中的場景啟動器


ps:切記不可再在pom.xml文件中引入mybatis與mybatis-spring的maven依賴,這一點,mybatis-plus的官方文檔中已經說明的很清楚了.

1.2、創建數據表

(1)SQL語句



(2) 數據表結構

1.3、 創建java bean

根據數據表新建相關實體類

1 package com.example.demo.pojo



1.4、 配置application.proprties

數據源使用druid



ps:在進行crud實驗之前,簡單對mybatis與mybatis-plus做一個簡單的對比

2.1、mybatis與mybatis-plus實現方式對比

(1)提出問題: 假設我們已存在一張 tbl_employee 表,且已有對應的實體類 Employee,實現 tbl_employee 表的 CRUD操作我們需要做什麼呢?

(2)實現方式: 基於 Mybatis 需要編寫 EmployeeMapper 介面,並手動編寫 CRUD 方法 提供 EmployeeMapper.xml 映射文件,並手動編寫每個方法對應的 SQL 語句. 基於 Mybatis-plus 只需要創建 EmployeeMapper 介面, 並繼承BaseMapper 介面.這就是使用 mybatis-plus 需要完成的所有操作,甚至不需要創建 SQL 映射文件。

2.2、BaseMapper介面介紹

(1)如何理解核心介面BaseMapper?

在使用Mybatis-Plus時,核心操作類是BaseMapper介面,其最終也是利用的Mybatis介面編程的實現機制,其默認提供了一系列的增刪改查的基礎方法,並且開發人員對於這些基礎操作不需要寫SQL進行處理操作(Mybatis提供的機制就是需要開發人員在mapper.xml中提供sql語句),那樣我們可以猜測肯定是Mybatis-Plus完成了BaseMapper介面提供的方法的SQL語句的生成操作。

(2)BaseMapper介面為我們定義了哪些方法?

BaseMapper介面源碼:





(3) mybatis-plus中常用的註解 1


由於我們的數據表名於實體類的類名不一致,並且實體類於數據表還存在欄位名不對應的情況,因此我們需要引入mybatis-plus的註解.



編寫EmployeeMapper介面繼承BaseMapper介面



准備考試環境:



(1)插入



(2)修改



控制台列印出的sql語句

如果我們不設置實體類的email與gender屬性,結果是怎樣的呢?



控制台sql語句:

顯然,mybatis-plus為我們做了非空判斷,空值的話,默認不更新對應的欄位.想一想,這是不是類似於mybatis中的動態sql呢?

這種處理效果又會帶來什麼好處呢?

(3)查詢



selectById方法



selectBatchIds方法



ps:發現該方法底層使用的竟然是sql的in關鍵字

selectByMap方法



(4)刪除



3、不得不提的條件構造器---Wrapper

3.1.wrapper及其子類介紹

(1)Wrapper :條件構造抽象類,最頂端父類,抽象類中提供3個方法以及其他方法.

⑸ 初看Mybatis 源碼 SQL是怎麼執行的

一條sql語句到底是怎麼執行的?我們知道Mybatis其實是對JDBC的一個封裝。假如我執行
session.update("com.mybatis..AuthUserDao.updateAuthUserEmailByName", [email protected]);
語句,追蹤下來,Executor、 BaseStatementHandler等等。在 SimpleExecutor 中有如下代碼:
public int doUpdate(MappedStatement ms, Object parameter) throws SQLException {
Statement stmt = null;
try {
Configuration configuration = ms.getConfiguration();
StatementHandler handler = configuration.newStatementHandler(this, ms, parameter, RowBounds.DEFAULT, null, null);
stmt = prepareStatement(handler, ms.getStatementLog());
return handler.update(stmt);
} finally {
closeStatement(stmt);
}
}
1. 首先獲取相關配置信息,這個在初始化時,從配置文件中解析而來
2. 新建了一個handler
3. 做了執行statement之前的准備工作。看看準備了些什麼,跟蹤代碼,最後進入了DataSource類的doGetConnection方法,該方法做如下操作:
private Connection doGetConnection(Properties properties) throws SQLException {
initializeDriver();
Connection connection = DriverManager.getConnection(url, properties);
configureConnection(connection);
return connection;
}

private synchronized void initializeDriver() throws SQLException {
if (!registeredDrivers.containsKey(driver)) {
Class<?> driverType;
try {
if (driverClassLoader != null) {
driverType = Class.forName(driver, true, driverClassLoader);
} else {
driverType = Resources.classForName(driver);
}
// DriverManager requires the driver to be loaded via the system ClassLoader.
// http://www.kfu.com/~nsayer/Java/dyn-jdbc.html
Driver driverInstance = (Driver)driverType.newInstance();
DriverManager.registerDriver(new DriverProxy(driverInstance));
registeredDrivers.put(driver, driverInstance);

閱讀全文

與mybatis語句源碼相關的資料

熱點內容
控制面板命令行 瀏覽:49
為什麼空氣難壓縮是因為斥力嗎 瀏覽:641
郭天祥單片機實驗板 瀏覽:599
伺服器有什麼危害 瀏覽:256
飢荒怎麼開新的獨立伺服器 瀏覽:753
文件夾變成了 瀏覽:560
linuxpython綠色版 瀏覽:431
怎麼下載小愛同學音箱app 瀏覽:554
python佔位符作用 瀏覽:76
javajdbcpdf 瀏覽:543
php網頁模板下載 瀏覽:192
python試講課pygame 瀏覽:409
安居客的文件夾名稱 瀏覽:677
家裡伺服器如何玩 瀏覽:451
網站源碼使用視頻 瀏覽:748
stc89c52單片機最小系統 瀏覽:452
郵件安全證書加密 瀏覽:416
雲伺服器如何訪問百度 瀏覽:279
常州電信伺服器dns地址 瀏覽:839
用小方塊製作解壓方塊 瀏覽:42