[Mybatis-plus]

簡介

????????MyBatis-Plus (簡稱 MP)是一個 MyBatis的增強工具,在 MyBatis 的基礎上只做增強不做改變。Mybatis-plus官網地址

? ? ? ? 注意,在引入了mybatis-plus之后,不要再額外引入mybatis和mybatis-spring,避免因為版本差異導致的問題。

快速上手

1.導入依賴

根據自身環境的版本選擇mybatis-plus版本:

springboot3.+和jdk17以上版本選擇mybatis-plus-boot3-starter

<!-- https://mvnrepository.com/artifact/com.baomidou/mybatis-plus-boot-starter -->
<dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot3-starter</artifactId><version>yourversion</version>
</dependency>

其他老版本選擇mybatis-plus-boot-starter

<!-- https://mvnrepository.com/artifact/com.baomidou/mybatis-plus-spring-boot3-starter -->
<dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-spring-boot-starter</artifactId><version>yourversion</version>
</dependency>

2.編寫配置:

jdbc連接配置(username、password、驅動)

Mybatis配置(連接池對象、映射文件所在包等)

編寫配置的具體形式看自己使用的是spring還是springboot

3.編寫實體類和mapper接口

? ? ? ? plus提供了一系列默認的sql方法,僅測試可以不用額外自己編寫。

常用注解

? ? ? ? 先看一個示范實體類:

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;@TableName("user")
public class MyUser {@TableId(value = "id", type = IdType.AUTO)private int id;@TableField("name")private String name;public int getId() {return id;}public void setId(int id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}@Overridepublic String toString() {return "MyUser{" +"id=" + id +", name='" + name + '\'' +'}';}
}

@TableName

? ? ? ? 用于指定當前實體類對應數據庫中哪張表

@TableId

? ? ? ? 給屬性綁定表中的主鍵,其中type屬性是聲明主鍵策略:

IdType.AUTO?? ?數據庫自增主鍵(需數據庫支持,如 MySQL 的 AUTO_INCREMENT)

IdType.ASSIGN_ID?? ?雪花算法生成 Long 類型主鍵(默認策略)

IdType.ASSIGN_UUID?? ?UUID 生成字符串類型主鍵(需字段類型為 String)

IdType.INPUT?? ?手動輸入主鍵(需在代碼中賦值)

IdType.NONE?? ?無策略,依賴數據庫默認行為

@TableField

? ? ? ? 給屬性綁定表中的列

? ? ? ? 當然,上述是對應單表的時候。如果你的查詢結果對應多張表中的數據,就不再能夠用這三個注解了。

? ? ? ? 我們在多表查詢的語句中使用別名,mybatis會自動匹配查詢結果和實體類的數據:

// DTO 類(無需繼承任何基類)
public class UserOrderDTO {// 用戶表字段private Long userId;private String userName;// 訂單表字段private String orderId;private BigDecimal orderAmount;// 其他字段(如關聯表的統計信息)private Integer totalOrders;// Getters & Setters
}
<!-- XML 中編寫 SQL -->
<select id="selectUserOrders" resultType="com.example.dto.UserOrderDTO">SELECT u.id          AS userId,u.name        AS userName,o.order_id    AS orderId,o.amount      AS orderAmount,COUNT(o.id)   AS totalOrdersFROM user uLEFT JOIN order o ON u.id = o.user_idWHERE u.id = #{userId}GROUP BY u.id
</select>

條件構造器

? ? ? ? 條件構造器的相關功能通過一系列Wrapper類實現。

下面是兩組示范:

sql語句:select name,email from tb_user where address like 值1 and age>=值2;

QueryWrapper<User> queryWrapper = new QueryWrapper<User>();queryWrapper.select("name","email").like("address","a").gt("age","30");

sql語句:update tb_user set age = age+10 where uid in(1,3,5);

UpdateWrapper<User> updateWrapper = new UpdateWrapper<>();updateWrapper.setSql("age = age+10").in("uid", Arrays.asList(1,3,5));

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

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

相關文章

管理100個小程序-很難嗎

20公里的徒步-真難 群里的伙伴發起了一場天目山20公里徒步的活動&#xff0c;想著14公里都輕松拿捏了&#xff0c;思考了30秒后&#xff0c;就借著春風帶著老婆孩子就出發了。一開始溪流清澈見底&#xff0c;小橋流水沒有人家&#xff1b;青山郁郁蔥蔥&#xff0c;枯藤老樹沒有…

大模型工業化元年:GPT-5開啟通用AI新紀元,中國技術如何破局?

過去一周&#xff0c;AI領域的焦點無疑是OpenAI發布的GPT-5預覽版&#xff0c;以及全球大模型技術從實驗室邁向工業化的關鍵轉折。這場變革不僅標志著通用人工智能&#xff08;AGI&#xff09;的進一步逼近&#xff0c;更掀起了全球產業鏈的競爭與反思。本文將從技術突破、產業…

軟考【網絡工程師】2023年5月上午題答案解析

1、固態硬盤的存儲介質是()。 A 光盤 B 閃存 C 軟盤 D 磁盤 答案是 B。 固態硬盤(Solid State Drive),簡稱 SSD,是用固態電子存儲芯片陣列制成的硬盤,其存儲介質是閃存(Flash Memory)。閃存具有非易失性,即在斷電后仍能保留存儲的數據,且讀寫速度快、抗震性強、能…

【速寫】鉤子與計算圖

文章目錄 前向鉤子反向鉤子的輸入反向鉤子的輸出 前向鉤子 下面是一個測試用的計算圖的網絡&#xff0c;這里因為模型是自定義的緣故&#xff0c;可以直接把前向鉤子注冊在模型類里面&#xff0c;這樣會更加方便一些。其實像以前BERT之類的last_hidden_state以及pool_output之…

高級電影感戶外街拍人像攝影后期Lr調色教程,手機濾鏡PS+Lightroom預設下載!

調色介紹 高級電影感戶外街拍人像攝影后期 Lr 調色&#xff0c;是運用 Adobe Lightroom 軟件&#xff0c;對戶外街拍的人像照片進行后期處理&#xff0c;以塑造出具有電影質感的獨特視覺效果。此調色過程借助 Lr 豐富的工具與功能&#xff0c;從色彩、光影、對比度等多維度著手…

16.QT-Qt窗口-菜單欄|創建菜單欄|添加菜單|創建菜單項|添加分割線|添加快捷鍵|子菜單|圖標|內存泄漏(C++)

Qt窗?是通過QMainWindow類來實現的。 QMainWindow是?個為??提供主窗?程序的類&#xff0c;繼承?QWidget類&#xff0c;并且提供了?個預定義的布局。QMainWindow包含?個菜單欄&#xff08;menu bar&#xff09;、多個?具欄(tool bars)、多個浮動窗?&#xff08;鉚接部…

【kafka初學】啟動執行命令

接上篇&#xff0c;啟動&#xff1a;開兩個cdm窗口 注意放的文件不要太深或者中文&#xff0c;會報命令行太長的錯誤 啟動zookeeper bin\windows\zookeeper-server-start.bat config\zookeeper.properties2. 啟動kafka-serve bin\windows\kafka-server-start.bat config\serv…

利用 Claw Cloud Run 免費應用部署前端網頁

一、注冊 使用注冊180天的github賬戶注冊Claw Cloud賬戶&#xff0c;可獲得每月5$的免費配額官網鏈接 - https://run.claw.cloud/ &#xff08;ps&#xff1a;直接github賬號登錄應該就不用寫了吧&#xff09; 二、創建應用 打開App Launchpad 點擊Create AppCPU選0.1即可&a…

豆瓣圖書數據采集與可視化分析(三)- 豆瓣圖書數據統計分析

文章目錄 前言一、數據讀取與保存1. 讀取清洗后數據2. 保存數據到CSV文件3. 保存數據到MySQL數據庫 二、不同分類統計分析1. 不同分類的圖書數量統計分析2. 不同分類的平均評分統計分析3. 不同分類的平均評價人數統計分析4. 不同分類的平均價格統計分析5. 分類綜合分析 三、不同…

網絡原理 - 3(UDP 協議)

目錄 協議 應用層 xml json protobuffer 傳輸層 端口號&#xff08;Port&#xff09; UDP 協議 UDP 協議端格式 完&#xff01; 協議 網絡通信中&#xff0c;協議是一個非常重要的概念。我們前面在網絡原理中&#xff0c;就已經介紹了&#xff0c;為了統一各方網絡&…

Java Agent 注入 WebSocket 篇

Agent 如果要對其進行Agent注入的編寫&#xff0c;需要先理解三個名字premain&#xff0c;agentmain&#xff0c;Instrumentation premain方法在 JVM 啟動階段調用&#xff0c;一般維持權限的時候不會使用 agentmain方法在 JVM 運行時調用 常用的 Instrumentation實例為代理…

【深度強化學習 DRL 快速實踐】近端策略優化 (PPO)

PPO&#xff08;2017&#xff0c;OpenAI&#xff09;核心改進點 Proximal Policy Optimization (PPO)&#xff1a;一種基于信賴域優化的強化學習算法&#xff0c;旨在克服傳統策略梯度方法在更新時不穩定的問題&#xff0c;采用簡單易實現的目標函數來保證學習過程的穩定性 解決…

筆試強訓:Day2

一、字符串中找出連續最長的數字串(雙指針) 字符串中找出連續最長的數字串_牛客題霸_牛客網 #include <iostream> #include <string> #include <cctype> using namespace std;int main() {//雙指針string str;cin>>str;int nstr.size();int begin-1,l…

MySQL 詳解之 InnoDB:核心特性深度剖析 (ACID, 事務, 鎖, 外鍵, 崩潰恢復)

在 MySQL 的世界里,存儲引擎是數據庫管理系統的核心組成部分,它負責數據的存儲和提取。MySQL 支持多種存儲引擎,如 MyISAM, Memory, CSV 等,但自 MySQL 5.5 版本以來,InnoDB 成為了默認的存儲引擎,也是絕大多數應用場景的首選。 為什么 InnoDB 如此重要并被廣泛采用?因…

Java中正則表達式使用方法

1. 正則表達式概述 正則表達式&#xff08;Regular Expression&#xff0c;簡稱 Regex&#xff09;是一種用于匹配字符串的模式工具。在 Java 中&#xff0c;正則表達式通過 java.util.regex 包實現&#xff0c;主要涉及以下兩個類&#xff1a; Pattern&#xff1a;表示一個編…

使用瀏覽器的Clipboard API實現前端復制copy功能

在前端開發中&#xff0c;復制文本到剪貼板的功能通常使用瀏覽器的 Clipboard API 實現。比如 navigator.clipboard.writeText 方法。以下是一個簡單的案例&#xff0c;展示如何使用 Clipboard API 實現復制文本的功能。 基本用法 首先&#xff0c;你需要創建一個按鈕&#x…

【因果推斷】(二)CV中的應用

文章目錄 因果表征學習因果圖 (Causal Diagram)“后門準則”&#xff08;backdoor criterion&#xff09;和“前門準則”&#xff08;frontdoor criterion&#xff09;后門調整Visual Commonsense R-CNNCausal Intervention for Weakly-Supervised Semantic SegmentationCausal…

【iOS】alloc init new底層原理

目錄 前言 alloc alloc核心操作 cls->instanceSize(extraBytes) calloc obj->initInstanceIsa init 類方法&#xff1a; 實例方法&#xff1a; new 前言 筆者最近在進行對OC語言源碼的學習&#xff0c;學習源碼的過程中經常會出現一些從來沒有遇見過的函數&…

QT窗口相關控件及其屬性

widget&#xff0c;PushButton&#xff0c;lineEdit等都是基于QWidget延展出來的 并不是完整的窗口&#xff0c;而是作為窗口的一部分 真正的窗口是QMainWindow 菜單欄 Qt中的菜單欄是通過QMenuBar這個類來實現的&#xff0c;一個主窗口最多只有一個菜單欄&#xff0c;位于主…

day47—雙指針-平方數之和(LeetCode-633)

題目描述 給定一個非負整數 c &#xff0c;你要判斷是否存在兩個整數 a 和 b&#xff0c;使得 a^2 b^2 c 。 示例 1&#xff1a; 輸入&#xff1a;c 5 輸出&#xff1a;true 解釋&#xff1a;1 * 1 2 * 2 5示例 2&#xff1a; 輸入&#xff1a;c 3 輸出&#xff1a;f…