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

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

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

簡介:

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

特性:

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

支持數(shù)據(jù)庫:

  • 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 增強工具包,簡化 CRUD 操作。 文檔 http://baomidou.com低代碼組件庫 http://aizuda.com
文檔發(fā)布地址:https://baomidou.com/pages/24112f

入門案例:

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

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)入依賴:

<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 插件:

編寫代碼:

application.yml

spring:
# 配置數(shù)據(jù)源信息
datasource:
  # 配置數(shù)據(jù)源類型
  type: com.zaxxer.hikari.HikariDataSource
  # 配置連接數(shù)據(jù)庫信息
  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ū)動類:driver-class-name
SpringBoot 2.0(內(nèi)置 jdbc5驅(qū)動),驅(qū)動類使用:driver-class-name:comment.mysql.jdbc.Driver
SpringBoot 2.1及以上(內(nèi)置 jdbc8 驅(qū)動),驅(qū)動類使用: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
否則運行測試用例報如下錯誤:

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

啟動類:

在 SpringBoot 啟動類中添加 @MapperScan 注解,掃描 mapper 包

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

添加實體類:

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

添加 Mapper:

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

public interface UserMapper extends BaseMapper<User> {
}

測試:

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

添加日志:

在 application.yml 中配置日志輸出

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

結(jié)果:

注意:

  • IDEA 在 userMapper 處報錯,因為找不到注入的對象,因為類是動態(tài)創(chuàng)建的,但是程序可以正確的運行
  • 為了避免報錯,可以在 mapper 接口上添加 @Repository 注解

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

相關(guān)文章

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

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

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

    Springboot?注解EqualsAndHashCode詳解

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

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

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

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

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

    解決報錯:java.lang.IllegalStateException: Failed to&nb

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

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

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

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

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

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

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

    Mybatis mapper標簽中配置子標簽package的坑及解決

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

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

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

最新評論