SpringBoot3整合mybatis-plus的實(shí)現(xiàn)
Mybatis簡(jiǎn)介
MyBatis-Plus是一個(gè)基于MyBatis的增強(qiáng)工具,它簡(jiǎn)化了與數(shù)據(jù)庫的交互和操作。它提供了一系列的便利功能,可以減少編寫重復(fù)的SQL代碼和簡(jiǎn)化數(shù)據(jù)訪問層的開發(fā)。
MyBatis-Plus的主要特點(diǎn)和功能:
- 代碼生成器:MyBatis-Plus提供了一個(gè)代碼生成器,可以根據(jù)數(shù)據(jù)庫表結(jié)構(gòu)自動(dòng)生成實(shí)體類、Mapper接口和XML映射文件的代碼,減少了手動(dòng)編寫重復(fù)的CRUD操作的工作量。
- 通用CRUD操作:MyBatis-Plus提供了一套通用的CRUD操作方法,包括插入、更新、刪除和查詢等,可以大大簡(jiǎn)化數(shù)據(jù)庫操作的代碼編寫。
- 強(qiáng)大的查詢構(gòu)建器:MyBatis-Plus提供了一個(gè)靈活而強(qiáng)大的查詢構(gòu)建器,可以通過鏈?zhǔn)秸{(diào)用的方式構(gòu)建復(fù)雜的查詢條件,支持動(dòng)態(tài)條件拼接和排序等操作。
- 分頁查詢支持:MyBatis-Plus內(nèi)置了分頁查詢的支持,可以方便地進(jìn)行分頁查詢操作。
- 邏輯刪除支持:MyBatis-Plus支持邏輯刪除,可以通過配置實(shí)現(xiàn)將刪除操作轉(zhuǎn)換為更新操作,便于數(shù)據(jù)的恢復(fù)和管理。
- 自動(dòng)填充字段:MyBatis-Plus支持自動(dòng)填充字段的功能,可以在插入和更新操作時(shí)自動(dòng)填充指定的字段值,例如創(chuàng)建時(shí)間和更新時(shí)間等。
- 樂觀鎖支持:MyBatis-Plus提供了樂觀鎖的支持,可以通過版本號(hào)或時(shí)間戳等機(jī)制實(shí)現(xiàn)并發(fā)控制,避免數(shù)據(jù)沖突和并發(fā)更新問題。
快速入門
1、添加依賴
<!-- MySql驅(qū)動(dòng) --> <dependency> <groupId>com.mysql</groupId> <artifactId>mysql-connector-j</artifactId> <scope>runtime</scope> </dependency> <!-- MyBatisPlus --> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.5.3.1</version> </dependency>
2、添加配置
#mybatis mybatis-plus: mapper-locations: classpath*:/mapper/**/*.xml,classpath:/META-INF/modeler-mybatis-mappings/*.xml #實(shí)體掃描,多個(gè)package用逗號(hào)或者分號(hào)分隔 typeAliasesPackage: com.kopensoft.modules.*.entity global-config: #數(shù)據(jù)庫相關(guān)配置 db-config: #主鍵類型 id-type: ASSIGN_ID banner: false spring: datasource: driver-class-name: com.mysql.cj.jdbc.Driver url: jdbc:mysql://localhost:3306/study?allowPublicKeyRetrieval=true&useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai&nullCatalogMeansCurrent=true username: root password: 123456
3、增加包掃描的注解
@MapperScan(basePackages = “com.kopensoft.modules.*.mapper”)
package com.kopensoft; import org.mybatis.spring.annotation.MapperScan; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @MapperScan(basePackages = "com.kopensoft.modules.*.mapper") @SpringBootApplication public class KopensoftAdminApplication { public static void main(String[] args) { SpringApplication.run(KopensoftAdminApplication.class, args); } }
4、用戶實(shí)例加測(cè)試
創(chuàng)建表
-- study.sys_user definition CREATE TABLE `sys_user` ( `id` int NOT NULL AUTO_INCREMENT, `username` varchar(100) DEFAULT NULL, `password` varchar(100) DEFAULT NULL, PRIMARY KEY (`id`), KEY `sys_user_id_IDX` (`id`) USING BTREE ) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;
創(chuàng)建實(shí)體類
import com.baomidou.mybatisplus.annotation.IdType; import com.baomidou.mybatisplus.annotation.TableField; import com.baomidou.mybatisplus.annotation.TableId; import com.baomidou.mybatisplus.annotation.TableName; import lombok.Data; import nonapi.io.github.classgraph.json.Id; @TableName("sys_user") @Data public class UserEntity { @TableId(type = IdType.AUTO) // 主鍵ID,自增策略 private Long id; // 用戶名 private String username; // 密碼 private String pwd; }
MyBatis-Plus中常用的注解主要包括以下幾種:
@TableName:用于指定實(shí)體類對(duì)應(yīng)的數(shù)據(jù)庫表名,可以在注解中設(shè)置表名。
@TableId:用于指定實(shí)體類中的字段作為主鍵,并指定主鍵生成策略。常用的主鍵生成策略包括:
IdType.AUTO
:自增主鍵。IdType.NONE
:無主鍵。IdType.INPUT
:手動(dòng)輸入主鍵。IdType.ID_WORKER
:全局唯一ID,數(shù)字類型。IdType.UUID
:全局唯一ID,字符串類型。
@TableField:用于指定實(shí)體類中的字段與數(shù)據(jù)庫表中的字段的映射關(guān)系。常用的屬性包括:
value
:指定數(shù)據(jù)庫表中的字段名。exist
:指定該字段是否在數(shù)據(jù)庫表中存在,默認(rèn)為true。fill
:指定該字段是否為自動(dòng)填充字段,默認(rèn)為false。insertStrategy
:指定插入操作的填充策略。updateStrategy
:指定更新操作的填充策略。whereStrategy
:指定查詢操作的填充策略。
@TableLogic:用于指定邏輯刪除字段,標(biāo)記該字段為邏輯刪除字段。邏輯刪除是通過修改字段的值來表示刪除狀態(tài),而不是直接從數(shù)據(jù)庫中刪除記錄。
@Version:用于樂觀鎖字段的標(biāo)記,標(biāo)記該字段為樂觀鎖字段。樂觀鎖是一種并發(fā)控制機(jī)制,通過比較字段的值來實(shí)現(xiàn)并發(fā)更新的控制。
@EnumValue:用于枚舉類型字段的標(biāo)記,標(biāo)記該字段為枚舉類型字段。
創(chuàng)建 mapper
import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.kopensoft.common.modules.security.entity.UserEntity; import org.apache.ibatis.annotations.Mapper; @Mapper public interface UserMapper extends BaseMapper<UserEntity> { }
MyBatis-Plus的BaseMapper是一個(gè)通用的Mapper接口,提供了一系列常用的數(shù)據(jù)庫操作方法。通過繼承BaseMapper接口,可以直接使用這些方法,無需手動(dòng)編寫SQL語句。
以下是BaseMapper接口的一些常用方法:
- insert:插入一條記錄到數(shù)據(jù)庫表中。
- deleteById:根據(jù)主鍵ID刪除數(shù)據(jù)庫表中的一條記錄。
- updateById:根據(jù)主鍵ID更新數(shù)據(jù)庫表中的一條記錄。
- selectById:根據(jù)主鍵ID查詢數(shù)據(jù)庫表中的一條記錄。
- selectList:查詢數(shù)據(jù)庫表中的所有記錄。
- selectPage:分頁查詢數(shù)據(jù)庫表中的記錄。
- selectCount:查詢數(shù)據(jù)庫表中的記錄總數(shù)。
- selectOne:根據(jù)條件查詢數(shù)據(jù)庫表中的一條記錄。
- 除了上述常用方法,BaseMapper還提供了一些其他方法,如條件查詢、批量操作、邏輯刪除等,具體可以根據(jù)需求查看官方文檔。
創(chuàng)建mapper對(duì)應(yīng)的xml
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.kopensoft.modules.sys.mapper.UserMapper"> </mapper>
mapper對(duì)應(yīng)的xml中常用標(biāo)簽
:XML文件的根元素,用于定義Mapper接口的映射配置。
:用于定義查詢操作的映射關(guān)系。
id:查詢操作的唯一標(biāo)識(shí)符。
resultType:查詢結(jié)果的映射類型,即返回的實(shí)體類類型。
parameterType:查詢參數(shù)的映射類型,即傳入的參數(shù)類型。
:用于動(dòng)態(tài)拼接SQL語句的條件判斷。
:用于循環(huán)遍歷集合,并生成對(duì)應(yīng)的SQL語句片段。
:用于定義插入操作的映射關(guān)系。
id:插入操作的唯一標(biāo)識(shí)符。
parameterType:插入?yún)?shù)的映射類型,即傳入的參數(shù)類型。
:用于獲取插入操作生成的主鍵值。
:用于定義更新操作的映射關(guān)系。
id:更新操作的唯一標(biāo)識(shí)符。
parameterType:更新參數(shù)的映射類型,即傳入的參數(shù)類型。
:用于定義刪除操作的映射關(guān)系。
id:刪除操作的唯一標(biāo)識(shí)符。
parameterType:刪除參數(shù)的映射類型,即傳入的參數(shù)類型。
:用于定義結(jié)果集的映射關(guān)系。
id:結(jié)果集的唯一標(biāo)識(shí)符。
type:結(jié)果集的映射類型,即返回的實(shí)體類類型。
:用于定義字段與實(shí)體類屬性的映射關(guān)系。
:用于定義可重用的SQL語句片段。
id:SQL片段的唯一標(biāo)識(shí)符。
:用于引入可重用的SQL語句片段。
refid:引用的SQL片段的唯一標(biāo)識(shí)符。
使用測(cè)試類測(cè)試一下
package com.kopensoft; import com.kopensoft.modules.sys.mapper.entity.UserEntity; import com.kopensoft.modules.sys.mapper.UserMapper; import org.junit.jupiter.api.Test; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.context.SpringBootTest; import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder; @SpringBootTest public class UserMapperTest { @Autowired private UserMapper userMapper; @Test public void testInsert() { BCryptPasswordEncoder encoder = new BCryptPasswordEncoder(); UserEntity user = new UserEntity(); user.setUsername("admin"); user.setPwd(encoder.encode("123456")); userMapper.insert(user); } }
使用Mybatis-Plus插件生成代碼
https://baomidou.com/pages/ba5b24/
到此這篇關(guān)于SpringBoot3整合mybatis-plus的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)SpringBoot整合mybatis-plus內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- SpringBoot整合Mybatis-plus實(shí)現(xiàn)多級(jí)評(píng)論功能
- Springboot3整合Mybatis-plus3.5.3報(bào)錯(cuò)問題解決
- SpringBoot整合mybatis-plus實(shí)現(xiàn)分頁查詢功能
- springboot3.2整合mybatis-plus詳細(xì)代碼示例
- SpringBoot3和mybatis-plus整合出現(xiàn)的問題解決辦法
- SpringBoot3.2.2整合MyBatis-Plus3.5.5依賴不兼容的問題解決
- SpringBoot整合Mybatis-Plus實(shí)現(xiàn)關(guān)聯(lián)查詢
- 全網(wǎng)最新springboot整合mybatis-plus的過程
- SpringBoot3.3.X整合Mybatis-Plus的實(shí)現(xiàn)示例
相關(guān)文章
SpringBoot返回統(tǒng)一的JSON標(biāo)準(zhǔn)格式實(shí)現(xiàn)步驟
這篇文章主要介紹了SpringBoot返回統(tǒng)一的JSON標(biāo)準(zhǔn)格式,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-08-08Java正則表達(dá)式易錯(cuò)知識(shí)點(diǎn)匯總
這篇文章主要總結(jié)Java正則表達(dá)式易錯(cuò)知識(shí),對(duì)易錯(cuò)知識(shí)點(diǎn)進(jìn)行分類整理,幫助大家更好的學(xué)習(xí)Java正則表達(dá)式,感興趣的小伙伴們可以參考一下2015-12-12Java參數(shù)傳遞及值傳遞實(shí)現(xiàn)原理詳解
這篇文章主要介紹了Java參數(shù)傳遞及值傳遞實(shí)現(xiàn)原理詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08JSON.toJSONString()方法在Java中的使用方法及應(yīng)用場(chǎng)景
這篇文章主要給大家介紹了關(guān)于JSON.toJSONString()方法在Java中的使用方法及應(yīng)用場(chǎng)景,JSON.toJSONString是將對(duì)象轉(zhuǎn)化為Json字符串,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-04-04java 枚舉類定義靜態(tài)valueOf(java.lang.String)方法的問題及解決
這篇文章主要介紹了java 枚舉類定義靜態(tài)valueOf(java.lang.String)方法的問題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-09-09mybatis框架之mybatis中dao層開發(fā)的兩種方法
這篇文章主要介紹了mybatis框架之mybatis中dao層開發(fā)的兩種方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07