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

數(shù)據(jù)庫(kù)CURD必備搭檔mybatis?plus詳解

 更新時(shí)間:2022年05月27日 11:54:45   作者:把蘋果咬哭的測(cè)試筆記  
這篇文章主要為大家介紹了數(shù)據(jù)庫(kù)CURD必備搭檔mybatis?plus詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

一、什么是mybatis-plus

做開(kāi)發(fā),免不了對(duì)數(shù)據(jù)進(jìn)行增刪改查,那么mybatis-plus我覺(jué)得很適合我這個(gè)java新手,簡(jiǎn)單好用。
官網(wǎng)在這

MyBatis-Plus(簡(jiǎn)稱 MP),是一個(gè)MyBatis的增強(qiáng)工具,在MyBatis的基礎(chǔ)上只做增強(qiáng) 不做改變,為簡(jiǎn)化開(kāi)發(fā)、提高效率而生。
任何能使用mybatis進(jìn)行crud,并且支持標(biāo)準(zhǔn)sql的數(shù)據(jù)庫(kù),mp都可以勝任。

二、特性

  • 無(wú)侵入: 只做增強(qiáng)不做改變,引入它不會(huì)對(duì)現(xiàn)有工程產(chǎn)生影響,如絲般順滑
  • 損耗小: 啟動(dòng)即會(huì)自動(dòng)注入基本CURD,性能基本無(wú)損耗,直接面向?qū)ο蟛僮?/li>
  • 強(qiáng)大的CRUD: 內(nèi)置通用Mapper、通用Service,僅僅通過(guò)少量配置即可實(shí)現(xiàn)單表大部分CRUD操作,更有強(qiáng)大的條件構(gòu)造器,滿足各類使用需求
  • 支持Lambda形式調(diào)用: 通過(guò)Lambda表達(dá)式,方便的編寫(xiě)各類查詢條件,無(wú)需再擔(dān)心字段寫(xiě)錯(cuò)
  • 支持主鍵自動(dòng)生成: 支持多達(dá)4種主鍵策略(內(nèi)含分布式唯一 ID 生成器 - Sequence),可自由配置,完美解決主鍵問(wèn)題
  • 支持ActiveRecord模式: 支持ActiveRecord形式調(diào)用,實(shí)體類只需繼承Model類即可進(jìn)行強(qiáng)大的CRUD操作
  • 支持自定義全局通用操作: 支持全局通用方法注入( Write once, use anywhere )
  • 內(nèi)置代碼生成器: 采用代碼或者M(jìn)aven插件可快速生成Mapper 、Model 、Service 、Controller層代碼,支持模板引擎,更有超多自定義配置
  • 內(nèi)置分頁(yè)插件: 基于MyBatis物理分頁(yè),開(kāi)發(fā)者無(wú)需關(guān)心具體操作,配置好插件之后,寫(xiě)分頁(yè)等同于普通List查詢
  • 分頁(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í)啟用該功能,能快速揪出慢查詢
  • 內(nèi)置全局?jǐn)r截插件: 提供全表delete 、update操作智能分析阻斷,也可自定義攔截規(guī)則,預(yù)防誤操作

三、試一試

既然是來(lái)操作數(shù)據(jù)的,那得準(zhǔn)備好數(shù)據(jù)的環(huán)境。

1.建庫(kù)、建表、建數(shù)據(jù)

# 創(chuàng)建數(shù)據(jù)庫(kù)
CREATE DATABASE mybatis_plus;
# 創(chuàng)建表
DROP TABLE IF EXISTS user;
CREATE TABLE user
(
	id BIGINT(20) NOT NULL COMMENT '主鍵ID',
	name VARCHAR(30) NULL DEFAULT NULL COMMENT '姓名',
	age INT(11) NULL DEFAULT NULL COMMENT '年齡',
	email VARCHAR(50) NULL DEFAULT NULL COMMENT '郵箱',
	PRIMARY KEY (id)
);
# 插入數(shù)據(jù)
INSERT INTO user (id, name, age, email) VALUES
(1, 'wesson1', 18, 'pingguotest1@pingguo.com'),
(2, 'wesson2', 19, 'pingguotest1@pingguo.com'),
(3, 'wesson3', 20, 'pingguotest1@pingguo.com'),
(4, 'wesson4', 22, 'pingguotest1@pingguo.com'),
(5, 'wesson5', 20, 'pingguotest1@pingguo.com');

2.idea中創(chuàng)建工程、配置

為了方便,可以新建一個(gè)Spring Initializr工程。

配置pom.xml文件,可以修改下springboot的版本,我們使用穩(wěn)定版的2.2.1.RELEASE。

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.2.1.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>

接著添加maven依賴。

<dependencies>
        <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>
            <exclusions>
                <exclusion>
                    <groupId>org.junit.vintage</groupId>
                    <artifactId>junit-vintage-engine</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <!--mybatis-plus-->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.0.5</version>
        </dependency>
        <!--mysql-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>
        <!--lombok 簡(jiǎn)化實(shí)體類-->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.12</version>
        </dependency>
    </dependencies>

還有,在idea里安裝lombok插件。到settings里plugin下,搜索lombok回車,安裝即可。

3.配置數(shù)據(jù)庫(kù)

找到application.properties文件,路徑如圖所示,

spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://XXXXXX:3306/mybatis_plus?characterEncoding=UTF-8&serverTimezone=GMT%2B8
spring.datasource.username=XXXX
spring.datasource.password=XXXXX
#mybatis日志,在控制臺(tái)可以看到操作過(guò)程日志
mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl

注意:這里使用的是mysql8,springboot2.1以上的版本,集成了8.0版本的jdbc驅(qū)動(dòng),在url里加上后綴?characterEncoding=UTF-8&serverTimezone=GMT%2B8。
另外,driver-class-name也建議加上cj,com.mysql.cj.jdbc.Driver。因?yàn)橹暗腸om.mysql.jdbc.Driver已經(jīng)廢棄了,運(yùn)行的時(shí)候會(huì)有warning。

4.編寫(xiě)準(zhǔn)備代碼

在操作之前,還有些準(zhǔn)備代碼需要完成:

entity包下的user.java

package com.pingguo.mpdemo.entity;
import lombok.Data;
@Data
public class User {
    private Long id;
    private String name;
    private Integer age;
    private String email;
}

這里加上@Data注解即可,不要手動(dòng)的編寫(xiě)set、get、tostring方法了。

mapper包下的UserMapper.java

package com.pingguo.mpdemo.mapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.pingguo.mpdemo.entity.User;
import org.springframework.stereotype.Repository;
@Repository
public interface UserMapper extends BaseMapper<User> {
}

這是一個(gè)mapper接口,我們要繼承BaseMapper,把User實(shí)體傳進(jìn)去,就可以使用crud了。

配置掃描mapper的路徑

在啟動(dòng)類上,加個(gè)注解,mapper的路徑。

package com.pingguo.mpdemo;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
// 配置掃描mapper的路徑
@MapperScan("com.pingguo.mpdemo.mapper")
public class MpdemoApplication {
    public static void main(String[] args) {
        SpringApplication.run(MpdemoApplication.class, args);
    }
}

5.編寫(xiě)測(cè)試代碼

為了方便,可以直接在單元測(cè)試代碼里進(jìn)行crud操作。

查詢

因?yàn)槭孪任覀冊(cè)诒砝镆呀?jīng)插入了數(shù)據(jù),所以現(xiàn)在可以去把所有數(shù)據(jù)都查出來(lái)。

@SpringBootTest
class MpdemoApplicationTests {
    @Autowired
    private UserMapper userMapper;
    @Test
     void findAll() {
        List<User> users =  userMapper.selectList(null);
        System.out.println(users);
    }
}

因?yàn)槲覀兣渲昧薽ybatis的日志,所以在控制臺(tái)可以看到整個(gè)的操作過(guò)程。

新增、修改、刪除

//    新增
    @Test
    void addUser() {
        User user = new User();
        user.setName("pingguo");
        user.setAge(21);
        user.setEmail("pingguo@pingguo.com");
        userMapper.insert(user);
    }
//    刪除
    @Test
    void deleteUser() {
        userMapper.deleteById(1L);
    }
//    修改
    @Test
    void updateUser() {
        User user = new User();
        user.setId(2L);
        user.setName("修改名稱222");
        userMapper.updateById(user);
    }

新增、刪除、修改也很簡(jiǎn)單,可以通過(guò)日志看下執(zhí)行過(guò)程。

以上就是通過(guò)mp實(shí)現(xiàn)簡(jiǎn)單的增刪改查,很方便,其他內(nèi)容后面繼續(xù),更多關(guān)于mybatis plus數(shù)據(jù)庫(kù)CURD的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • SpringBoot內(nèi)置數(shù)據(jù)源的持久化與解決方案

    SpringBoot內(nèi)置數(shù)據(jù)源的持久化與解決方案

    數(shù)據(jù)源的配置 我們先基于SpringBoot默認(rèn)的HikariDataSource數(shù)據(jù)源,導(dǎo)入JDBC場(chǎng)景,看看SpringBoot幫我們自動(dòng)配置了什么,下面我們來(lái)了解SpringBoot內(nèi)置數(shù)據(jù)源持久化
    2022-07-07
  • Spring 4 支持的 Java 8 特性

    Spring 4 支持的 Java 8 特性

    Spring 框架 4 支持 Java 8 語(yǔ)言和 API 功能。在本文中,我們將重點(diǎn)放在 Spring 4 支持新的 Java 8 的功能。最重要的是 Lambda 表達(dá)式,方法引用,JSR-310的日期和時(shí)間,和可重復(fù)注釋。下面跟著小編一起來(lái)看下吧
    2017-03-03
  • springmvc的@Validated注解使用

    springmvc的@Validated注解使用

    這篇文章主要介紹了springmvc的@Validated注解使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • SpringBoot攔截器與文件上傳實(shí)現(xiàn)方法與源碼分析

    SpringBoot攔截器與文件上傳實(shí)現(xiàn)方法與源碼分析

    其實(shí)spring boot攔截器的配置方式和springMVC差不多,只有一些小的改變需要注意下就ok了。本文主要給大家介紹了關(guān)于如何在Springboot實(shí)現(xiàn)登陸攔截器與文件上傳功能,需要的朋友可以參考下
    2022-10-10
  • Jmerte分布式壓測(cè)及分布式壓測(cè)配置教程

    Jmerte分布式壓測(cè)及分布式壓測(cè)配置教程

    這篇文章主要介紹了Jmerte分布式壓測(cè)及分布式壓測(cè)配置,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-04-04
  • Java8 Lambda和Invokedynamic詳情

    Java8 Lambda和Invokedynamic詳情

    關(guān)于Java8的Lambda 我們可以將lambda表達(dá)式與新的Streams API結(jié)合起來(lái),以表達(dá)豐富的數(shù)據(jù)處理查詢,下面文章小編就列舉簡(jiǎn)單的例子給大家介說(shuō)吧,感興趣的小伙伴可以參考下面文章的具體內(nèi)容奧
    2021-09-09
  • JVM的類加載過(guò)程以及雙親委派模型詳解

    JVM的類加載過(guò)程以及雙親委派模型詳解

    這篇文章主要介紹了JVM的類加載過(guò)程以及雙親委派模型詳解,類加載器就是根據(jù)指定全限定名稱將 class 文件加載到 JVM 內(nèi)存,然后再轉(zhuǎn)化為 class 對(duì)象。,需要的朋友可以參考下
    2019-06-06
  • Spring Boot使用AOP實(shí)現(xiàn)REST接口簡(jiǎn)易靈活的安全認(rèn)證的方法

    Spring Boot使用AOP實(shí)現(xiàn)REST接口簡(jiǎn)易靈活的安全認(rèn)證的方法

    這篇文章主要介紹了Spring Boot使用AOP實(shí)現(xiàn)REST接口簡(jiǎn)易靈活的安全認(rèn)證的方法,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2018-11-11
  • 貨拉拉大數(shù)據(jù)對(duì)BitMap的探索實(shí)踐詳解

    貨拉拉大數(shù)據(jù)對(duì)BitMap的探索實(shí)踐詳解

    這篇文章主要為大家介紹了貨拉拉大數(shù)據(jù)對(duì)BitMap的探索實(shí)踐詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • Spring Boot項(xiàng)目如何同時(shí)支持HTTP和HTTPS協(xié)議的實(shí)現(xiàn)

    Spring Boot項(xiàng)目如何同時(shí)支持HTTP和HTTPS協(xié)議的實(shí)現(xiàn)

    這篇文章主要介紹了Spring Boot項(xiàng)目如何同時(shí)支持HTTP和HTTPS協(xié)議的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10

最新評(píng)論