MyBatis(Web后端開發第二期)

p.s.這是萌新自己自學總結的筆記,如果想學習得更透徹的話還是請去看大佬的講解

目錄

  • JDBC、數據庫連接池、lombok
  • 日志輸出
  • SQL注入
  • 數據封裝
  • XML映射文件
  • 動態SQL
    • `<if>`
    • `<where>`
    • `<set>`
    • `<foreach>`
    • `<sql>`
    • `<include>`
  • 配置文件

Mybatis是是一款優秀的數據訪問層框架,用于簡化JDBC的開發

使用Mybatis查詢所有用戶數據

  1. 準備工作(創建springboot工程、數據庫表user、實體類User)
  2. 引入Mybatis的相關依賴,配置Mybatis(數據庫連接信息:驅動類全類名、數據庫連接的URL、訪問數據庫的用戶名和密碼)
  3. 編寫SQL語句(注解/XML)
    在這里插入圖片描述

JDBC、數據庫連接池、lombok

JDBC(Java DataBase Connectivity)即使用java語言操作關系型數據庫的一套API
在這里插入圖片描述
JDBC本質是sun公司定義的一套操作所有關系型數據庫的規范,即接口
各個數據庫廠商去實現這套接口,提供數據庫驅動jar包
我們可以用這套接口(JDBC)編程,真正執行的代碼是驅動jar包中的實現類

數據庫連接池是個容器,負責分配、管理數據庫連接
它允許應用程序重復使用一個現有的數據庫進行連接,而不是重新再建立一個
釋放空間時間超過最大空閑時間的連接,來避免因為沒有釋放連接而引起的數據庫連接遺漏

優勢:資源重用、提升系統響應速度、避免數據庫連接遺漏

Lombok是一個實用的java類庫,能夠通過注解的形式自動生成構造器、getter/setter、equals、hashcode、toString等方法,并可以自動化生成日志變量,簡化java開發、提高效率
在這里插入圖片描述
lombok會在編譯時,自動生成對應的java代碼,我們使用lombok時,還需要安裝一個lombok的插件(idea自帶)

日志輸出

可以在application.properties中打開mybatis的日志,并指定輸出到控制臺
mybatis.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl

在這里插入圖片描述
預編譯sql不僅性能更高,而且更安全(防止sql注入)

SQL注入

SQL注入是通過操作輸入的數據來修改事先定義好SQL語句,以達到執行代碼對服務器進行攻擊的方法

數據封裝

實體類屬性名和數據庫查詢返回的字段名一致,mybatis會自動封裝
如果實體類屬性名和數據庫查詢返回的字段名不一致,mybatis則不會自動封裝

解決方案一:給字段起別名,讓別名和實體類屬性一致
解決方案二:通過@Results,@Result注解手動映射封裝
解決方案三:如果字段名與屬性名符合駝峰命名規則,則開啟mybatis的駝峰命名自動映射開關

XML映射文件

規范:
XML映射文件的名稱與Mapper接口名稱名字一致,并且將XML映射文件和Mapper接口放置在相同包下(同包同名)
XML映射文件的namespace屬性為Mapper接口全限定名一致
XML映射文件中sql語句的id與Mapper接口的方法名一致,并保持返回類型(單條記錄)一致
在這里插入圖片描述

動態SQL

隨著用戶的輸入或外部條件的變化而變化的SQL語句,稱為動態SQL
動態SQL用以下幾種標簽進行實現

<if>

<if>:用于判斷條件是否成立,使用Test屬性進行條件判斷,如果條件為true,則拼接SQL

在這里插入圖片描述

<where>

<where>:where元素只會在子元素有內容的情況下才插入where子句。而且會自動去除子句開頭的AND或者OR

<set>

<set>:動態的在行首插入SET關鍵字,并會刪除額外的逗號(用在update語句中)

<foreach>

在這里插入圖片描述

<sql>

<sql>:定義可重用的SQL片段

<include>

<include>:通過屬性refid,指定包含的sql片段

配置文件

在這里插入圖片描述

yml基本語法
大小寫敏感
數值前邊必須有空格,作為分隔符
使用縮進表示層級關系,縮進時,不允許使用tab鍵,只能用空格
縮進的空格數目不重要,只要相同層級的元素左側對齊即可
#表示注釋

在這里插入圖片描述

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/910565.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/910565.shtml
英文地址,請注明出處:http://en.pswp.cn/news/910565.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Angular1--Hello

最近有個小錯誤&#xff0c;因為最近還是在看thingsboard&#xff0c;最近終于看到前端的代碼&#xff0c;突然發現怎么全是ts的文件&#xff0c;仔細一看原來并不是之前認為的AngularJS&#xff0c;而是Angular。。。我tm真的無語了&#xff0c;又要去重新學。。。 Angular的…

什么是redission看門狗機制

Redisson 的看門狗機制(Watchdog Mechanism)是其實現可重入分布式鎖時的一個核心特性,主要用于解決業務邏輯執行時間超過鎖的過期時間(leaseTime)而導致鎖提前釋放,進而引發數據不一致的問題。它是一個自動的鎖續期機制。 ?? 核心問題:為什么需要看門狗? 分布式鎖的…

黑馬程序員蒼穹外賣DAY1

1. 前端頁面能正常顯示但無法登錄&#xff08;一直轉圈圈&#xff09; 找到下面路徑的dev.yml port一定要跟自己本機的保持一致&#xff0c;&#xff0c;username和password也一定是自己主機的用戶名和密碼&#xff0c;不然連不上。 登錄界面的密碼為數據庫表的密碼&#xff0…

Frida Hook Android App 點擊事件實戰指南:從進程識別到成功注入

一、背景與目標 在逆向分析和自動化測試中&#xff0c;Hook Android 的點擊事件是調試 UI 交互邏輯的重要手段之一。本文將以實際案例講解如何通過 Frida Hook public void onClick(View view) 方法&#xff0c;并解決常見的 Hook 失敗問題&#xff0c;最終實現對登錄按鈕的監…

Arduino Nano 33 BLE Sense Rev 2開發板使用指南之【環境搭建 / 點燈】

一、硬件介紹 1、產品特點 Arduino Nano 33 BLE Rev2&#xff0c;利用了nRF52840微控制器的先進功能。這款32位Arm Cortex-M4 CPU 64 MHz與MicroPython的兼容性增強了板子的靈活性&#xff0c;使其更容易被更廣泛的開發者社區所接受。 該開發板的突出特點是其藍牙低功耗&…

[QT]-宏使用

用宏,務必寫清文檔并用 do {…} while (0)為啥呢,示例 在 C/C++ 中,使用 do { … } while (0) 包裹宏定義是一種經典的最佳實踐,主要用于解決宏展開后的語法和邏輯問題。以下是詳細解釋和示例: 一、為什么用 do { … } while (0) 包裹宏? 避免分號導致的語法錯誤 問題場…

python-property、反射

# ### property """ 可以把方法變成屬性 : 可以動態的控制屬性的獲取,設置,刪除相關操作 property 獲取屬性 方法名.setter 設置屬性 方法名.deleter 刪除屬性 """ # 方法一 """是同一個方法名""" class MyCla…

【自動鼠標鍵盤控制器|支持圖像識別】

[軟件名稱]: 電腦圖像識別 [軟件大小]: 57.2 MB [下載通道]: 夸克盤 | 迅雷盤 &#x1f3ae;【自動鼠標鍵盤控制器&#xff5c;支持圖像識別】基于Python開發的智能自動化工具 輕量便捷的自動化操作工具&#xff0c;集成圖像識別、鼠標控制、鍵盤模擬等功能&#xff0c;輕松…

ISO/IEC 8824規范實際應用案例

案例 1&#xff1a;X.509 數字證書&#xff08;互聯網安全基石&#xff09; 標準依據&#xff1a;RFC 5280 (基于 ASN.1 定義) 核心應用&#xff1a; Certificate :: SEQUENCE {tbsCertificate TBSCertificate, -- 證書主體signatureAlgorithm AlgorithmIdentifier,…

QT6工程各種路徑詳解

一.當前工作目錄 1.獲取方法&#xff1a; #include <QDir> qDebug() << "當前工作目錄&#xff1a;" << QDir::currentPath(); 打印結果&#xff1a; 當前工作目錄&#xff1a; "D:/2.QT/test/test_console/build/QT6_8_2_64_MSVC-Release&…

1931. 用三種不同顏色為網格涂色

1931. 用三種不同顏色為網格涂色 mod_value 10**9 7 class Solution:def colorTheGrid(self, m: int, n: int) -> int:# 1、預處理所有合法的單行涂色方案# 存儲 3^i&#xff0c;用于快速計算顏色編碼的每一位&#xff08;類似位運算&#xff09;# [3^0, 3^1, 3^2, ...,…

整數的輸入輸出

整數的輸入輸出 兩種形式輸出&#xff1a;&#xff08;以int為界&#xff09; char、short、int都用 %dlong 和long long都用 %ld %d char、short、int%ld long long long%u unsignde%lu unsignde long long 整數的格式化輸出示例 #include <stdio.h> int main(){cha…

【llm實戰】Python打造BGE模型微調服務實戰指南

1. 引言:為何需要BGE模型微調?定制化語義的力量 BGE(BAAI General Embedding)是由北京智源人工智能研究院(BAAI)發布的通用文本嵌入模型系列,因其在中英文任務上的優異表現而廣受歡迎,尤其是在MTEB(Massive Text Embedding Benchmark)等權威榜單上名列前茅。 盡管通…

代碼分析與自動化重構

PS&#xff1a;根據過去編寫 Modernizing 相關的開源工具里&#xff0c;編寫的《代碼分析與自動化重構》指南。 遺留系統的現代化演進是一門藝術。在日常的軟件開發里&#xff0c;我們經常會遇到一系列的問題&#xff1a; 如何解決人類智商不夠的問題&#xff1f;模式、原則和…

【android bluetooth 框架分析 04】【bt-framework 層詳解 8】【DeviceProperties介紹】

前面我們提到了 藍牙協議棧中的 Properties &#xff0c; 這篇文章是 他的補充。 【android bluetooth 框架分析 04】【bt-framework 層詳解 6】【Properties介紹】 1. 設計初衷與核心問題 1. 為什么要設計 DeviceProperties&#xff1f; 在 Android 藍牙實際使用中&#x…

華為OD-2024年E卷-字母組合[200分] -- python

問題描述&#xff1a; 每個數字對應多個字母&#xff0c;對應關系如下&#xff1a; 0&#xff1a;a,b,c 1&#xff1a;d,e,f 2&#xff1a;g,h,i 3&#xff1a;j,k,l 4&#xff1a;m,n,o 5&#xff1a;p,q,r 6&#xff1a;s,t 7&#xff1a;u,v 8&#xff1a;w,x 9&#xff1…

機器學習競賽中的“A榜”與“B榜”:機制解析與設計深意

在Kaggle、天池等主流機器學習競賽平臺上&#xff0c;“A榜”&#xff08;Public Leaderboard&#xff09;和“B榜”&#xff08;Private Leaderboard&#xff09;是選手們最關注的指標。但很多新人對兩者的區別和設計意圖感到困惑。本文將深入解析其差異及背后的邏輯。 &#…

云徙科技 OMS:讓訂單管理變得輕松又高效

在如今這個線上線下購物融合得越來越緊密的時代&#xff0c;企業要是想在競爭激烈的市場里站穩腳跟&#xff0c;訂單管理這一塊可得好好下功夫。云徙科技的 OMS&#xff08;訂單管理系統&#xff09;就像是給企業量身打造的一把“金鑰匙”&#xff0c;能幫企業把訂單管理得井井…

qt常用控件--02

文章目錄 qt常用控件--02toolTip屬性focusPolicy屬性styleSheet屬性補充知識點按鈕類控件QPushButton 結語 很高興和大家見面&#xff0c;給生活加點impetus&#xff01;&#xff01;開啟今天的編程之路&#xff01;&#xff01; 今天我們進一步c11中常見的新增表達 作者&…

P3258 [JLOI2014] 松鼠的新家

題目描述 松鼠的新家是一棵樹&#xff0c;前幾天剛剛裝修了新家&#xff0c;新家有 n n n 個房間&#xff0c;并且有 n ? 1 n-1 n?1 根樹枝連接&#xff0c;每個房間都可以相互到達&#xff0c;且倆個房間之間的路線都是唯一的。天哪&#xff0c;他居然真的住在“樹”上。 …