欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MyBatis-Plus速成指南之簡(jiǎn)化你的數(shù)據(jù)庫(kù)操作流程(最新推薦)

 更新時(shí)間:2025年02月05日 10:57:23   作者:蘇-言  
MyBatis-Plus?是一個(gè)?MyBatis?的增強(qiáng)工具,在?MyBatis?的基礎(chǔ)上只做增強(qiáng)不做改變,為簡(jiǎn)化開(kāi)發(fā)、提高效率而生,這篇文章主要介紹了MyBatis-Plus速成指南:簡(jiǎn)化你的數(shù)據(jù)庫(kù)操作流程,需要的朋友可以參考下

簡(jiǎn)介:

  • MyBatis-Plus 是一個(gè) MyBatis 的增強(qiáng)工具,在 MyBatis 的基礎(chǔ)上只做增強(qiáng)不做改變,為簡(jiǎn)化開(kāi)發(fā)、提高效率而生。
  • MyBatsi-Plus 提供了通用的 Mapper 和 Service,可以不編寫(xiě)任何 SQL 語(yǔ)句的前提下,快速的實(shí)現(xiàn)單表的增刪改查(CURD),批量邏輯刪除,分頁(yè)等操作。只要把 MyBatis-Plus 的特性?xún)?yōu)秀插件,以及多數(shù)據(jù)源的配置進(jìn)行詳細(xì)講解

特性:

  • 無(wú)入侵:只做增強(qiáng)不做改變,引入它不會(huì)對(duì)現(xiàn)有工程產(chǎn)生影響
  • 損耗?。?jiǎn)?dòng)即會(huì)自動(dòng)注入基本 CURD,性能基本無(wú)損耗,直接面向?qū)ο蟛僮?/li>
  • 強(qiáng)大的 CURD 操作,更有強(qiáng)大的條件構(gòu)造器,滿(mǎn)足各類(lèi)使用需求
  • 支持 Lambda 形式調(diào)用:同過(guò) Lambda 表達(dá)式,方便的編寫(xiě)各類(lèi)條件查詢(xún),無(wú)需擔(dān)心字段寫(xiě)錯(cuò)
  • 支持主鍵自動(dòng)生成:支持多達(dá) 4 種主鍵策略(內(nèi)含分布式唯一 ID 生成器 - Sequence),可自由配置,完美解決主鍵問(wèn)題
  • 支持自定義全局通用操作:支持全局方法注入(Write once、use anywhere)
  • 內(nèi)置代碼生成器:采用代碼或者 Maven 插件可快速生成 Mapper、Model、Service、Controller 層代碼,支持模板引擎
  • 內(nèi)置分頁(yè)插件:基于 MyBatis 物理分頁(yè),開(kāi)發(fā)者無(wú)需關(guān)心具體操作,配置好插件后,寫(xiě)分頁(yè)等同于 List 查詢(xún)
  • 分頁(yè)插件支持多種數(shù)據(jù)庫(kù):支持 MySQL、MariaDB、Oracle、DB2、H2、HSQL、SQLite、Postgre、SQLServer 等多種數(shù)據(jù)庫(kù) 
  • 內(nèi)置性能分析插件:可輸出 SQL 語(yǔ)句以及其執(zhí)行時(shí)間,建議開(kāi)發(fā)測(cè)試時(shí)啟用該功能,能快速救出慢查詢(xún)
  • 內(nèi)置全局?jǐn)r截插件:提供全表delete、update操作,只能分析阻斷,也可自定義攔截規(guī)則,預(yù)防誤操作

支持?jǐn)?shù)據(jù)庫(kù):

  • MySQL、Oracle、DB2、H2、HSQL、SQLite、PostgreSQL、SQLServer、Phoenix、Gauss、ClickHouse、Sybase、OceanBase、Firebird、Cubrid、Foldilocks、csiidb

框架結(jié)構(gòu):

代碼及文檔地址:

官方地址:http://mp.baomidou.com
代碼發(fā)布地址:
GitHub:GitHub - baomidou/mybatis-plus: An powerful enhanced toolkit of MyBatis for simplify development
Gitee:mybatis-plus: mybatis 增強(qiáng)工具包,簡(jiǎn)化 CRUD 操作。 文檔 http://baomidou.com低代碼組件庫(kù) http://aizuda.com
文檔發(fā)布地址:https://baomidou.com/pages/24112f

入門(mén)案例:

創(chuàng)建數(shù)據(jù)庫(kù)和表:

CREATE DATABASE `mybatis_plus` /*!40100 DEFAULT CHARACTERSET utf8mb4 */; 
use `mybatis_plus`;
CREATE TABLE `user` (
`id` bigint(20) NOT NULL COMMENT '主鍵ID',
`name` varchar(30) DEFAULT NULL COMMENT '姓名 ',
`age` int(11) DEFAULT NULL COMMENT '年齡 ',
`email` varchar(50) DEFAULT NULL COMMENT '郵箱 ',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
INSERT INTO user (id, name, age, email) VALUES
(1, 'Jone', 18, 'test1@baomidou.com'),
(2, 'Jack', 20, 'test2@baomidou.com'),
(3, 'Tom', 28, 'test3@baomidou.com'),
(4, 'Sandy', 21, 'test4@baomidou.com'),
(5, 'Billie', 24, 'test5@baomidou.com');

創(chuàng)建 SpringBoot 工程 初始化工程:

導(dǎo)入依賴(lài):

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-test</artifactId>
    <scope>test</scope>
</dependency>
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>3.5.1</version>
</dependency>
<dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
    <optional>true</optional>
</dependency>
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <scope>runtime</scope>
</dependency>

IDEA  中安裝 Lombok 插件:

編寫(xiě)代碼:

application.yml

spring:
# 配置數(shù)據(jù)源信息
datasource:
  # 配置數(shù)據(jù)源類(lèi)型
  type: com.zaxxer.hikari.HikariDataSource
  # 配置連接數(shù)據(jù)庫(kù)信息
  driver-class-name: com.mysql.cj.jdbc.Driver
  url: jdbc:mysql://localhost:3306/mybatis_plus?characterEncoding=utf-8&useSSL=false
  username: root
  password: root

注意:
驅(qū)動(dòng)類(lèi):driver-class-name
SpringBoot 2.0(內(nèi)置 jdbc5驅(qū)動(dòng)),驅(qū)動(dòng)類(lèi)使用:driver-class-name:comment.mysql.jdbc.Driver
SpringBoot 2.1及以上(內(nèi)置 jdbc8 驅(qū)動(dòng)),驅(qū)動(dòng)類(lèi)使用:driver-class-name:comment.mysql.cj.jdbc.Driver
連接地址 URL:
MySQL5.7 的版本 url:
jdbc:mysql://localhost:3306/mybatis-plus?characterEncoding=utf-8&useSSl=false
MySQL8.0 版本的URL:
jdbc:mysql://localhost:3306/mybatis_plus?serverTimezone=GMTZ%2B8&characterEncoding=utf-8&useSSL=false
否則運(yùn)行測(cè)試用例報(bào)如下錯(cuò)誤:

a.java.sql.SQLException:The server timezone value'Öйú±ê׼ʱ¼ä' is unrecognized or representsmore

啟動(dòng)類(lèi):

在 SpringBoot 啟動(dòng)類(lèi)中添加 @MapperScan 注解,掃描 mapper 包

@SpringBootApplication
@MapperScan("com.qcby.mybatisplus.mapper")
public class MybatisplusApplication {
    public static void main(String[] args) {
        SpringApplication.run(MybatisplusApplication.class, args); 
    }
}

添加實(shí)體類(lèi):

@Data
public class User {
    private Long id;
    private String name;
    private Integer age;
    private String email;
}

添加 Mapper:

BaseMapper 時(shí) MyBatis-Plus 提供的 mapper 模板,其中包含了基本的 CURD 方法,泛型為操作的實(shí)體類(lèi)型

public interface UserMapper extends BaseMapper<User> {
}

測(cè)試:

@SpringBootTest
public class MyBatisPlusApplicationTests {
    @Autowired
    private UserMapper userMapper;
    @Test
    public void contextLoads() {
        //selectList() 根據(jù) MP 內(nèi)置的條件構(gòu)造器查詢(xún)一個(gè) list 集合,null 表示沒(méi)有條件,即查詢(xún)所有
        userMapper.selectList(null).forEach(System.out::println);
    }
}

添加日志:

在 application.yml 中配置日志輸出

# 配置MyBatis日志
mybatis-plus:
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

結(jié)果:

注意:

  • IDEA 在 userMapper 處報(bào)錯(cuò),因?yàn)檎也坏阶⑷氲膶?duì)象,因?yàn)轭?lèi)是動(dòng)態(tài)創(chuàng)建的,但是程序可以正確的運(yùn)行
  • 為了避免報(bào)錯(cuò),可以在 mapper 接口上添加 @Repository 注解

到此這篇關(guān)于MyBatis-Plus速成指南:簡(jiǎn)化你的數(shù)據(jù)庫(kù)操作流程的文章就介紹到這了,更多相關(guān)MyBatis-Plus數(shù)據(jù)庫(kù)操作內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Spring Boot LocalDateTime格式化處理的示例詳解

    Spring Boot LocalDateTime格式化處理的示例詳解

    這篇文章主要介紹了Spring Boot LocalDateTime格式化處理的示例詳解,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-10-10
  • Springboot?注解EqualsAndHashCode詳解

    Springboot?注解EqualsAndHashCode詳解

    注解@EqualsAndHashCode主要用于自動(dòng)生成equals方法和hashCode方法,callSuper屬性為true時(shí),生成的方法會(huì)包括父類(lèi)字段,為false則只包含當(dāng)前類(lèi)字段,IDEA工具中有檢查提示并可自動(dòng)修復(fù)相關(guān)代碼,確保注解正確使用,更多詳解可查閱相關(guān)文檔
    2024-10-10
  • SpringBoot源碼剖析之屬性文件加載原理

    SpringBoot源碼剖析之屬性文件加載原理

    這篇文章主要給大家介紹了關(guān)于SpringBoot源碼剖析之屬性文件加載原理的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2022-02-02
  • SpringBoot中過(guò)濾器Filter+JWT令牌實(shí)現(xiàn)登錄驗(yàn)證

    SpringBoot中過(guò)濾器Filter+JWT令牌實(shí)現(xiàn)登錄驗(yàn)證

    本文主要介紹了SpringBoot中過(guò)濾器Filter+JWT令牌實(shí)現(xiàn)登錄驗(yàn)證,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2024-04-04
  • 解決報(bào)錯(cuò):java.lang.IllegalStateException: Failed to execute CommandLineRunner問(wèn)題

    解決報(bào)錯(cuò):java.lang.IllegalStateException: Failed to&nb

    在項(xiàng)目開(kāi)發(fā)中,可能會(huì)遇到Elasticsearch啟動(dòng)報(bào)錯(cuò)的問(wèn)題,原因可能包括版本不一致、端口配置錯(cuò)誤、配置文件不匹配及服務(wù)未啟動(dòng)等,解決方法包括檢查進(jìn)程、重啟服務(wù)等,這些經(jīng)驗(yàn)可以幫助開(kāi)發(fā)者快速定位問(wèn)題并解決,保證項(xiàng)目順利運(yùn)行
    2024-10-10
  • Hibernate延遲加載技術(shù)詳解

    Hibernate延遲加載技術(shù)詳解

    這篇文章主要介紹了Hibernate延遲加載技術(shù),結(jié)合實(shí)例形式詳細(xì)分析了Hibernate延遲加載所涉及的各種常用技巧,需要的朋友可以參考下
    2016-03-03
  • springboot使用國(guó)產(chǎn)加密算法方式,sm2和sm3加解密demo

    springboot使用國(guó)產(chǎn)加密算法方式,sm2和sm3加解密demo

    這篇文章主要介紹了springboot使用國(guó)產(chǎn)加密算法方式,sm2和sm3加解密demo,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • IDEA如何添加配置文件到classpath中

    IDEA如何添加配置文件到classpath中

    這篇文章主要介紹了IDEA如何添加配置文件到classpath中,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-09-09
  • Mybatis mapper標(biāo)簽中配置子標(biāo)簽package的坑及解決

    Mybatis mapper標(biāo)簽中配置子標(biāo)簽package的坑及解決

    這篇文章主要介紹了Mybatis mapper標(biāo)簽中配置子標(biāo)簽package的坑及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • 關(guān)于SpringBoot打包測(cè)試、生產(chǎn)環(huán)境方式

    關(guān)于SpringBoot打包測(cè)試、生產(chǎn)環(huán)境方式

    這篇文章主要介紹了關(guān)于SpringBoot打包測(cè)試、生產(chǎn)環(huán)境方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-09-09

最新評(píng)論