SpringBoot框架——7.整合MybatisPlus

        这篇主要介绍Springboot整合MybatisPlus,另外介绍一个插件JBLSpringbootAppGen,以及一个经常用于测试的基于内存的h2数据库。

        Mybatisplus是mybatis的增强工具,和tk-mybatis相似,但功能更强大,可避免重复CRUD语句,先来一个简单入门:

1.安装一个插件:JBLSpringbootAppGen:

        File->Setting->Plugin: 搜索点击Install,重启IDEA

        这个工具主要用于创建启动类时自动创建配置文件。

2.新建一个modle: mybatis-plus-demo;

3.添加pom依赖:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.lxj</groupId>
    <artifactId>mybatis-plus-demo</artifactId>
    <version>1.0-SNAPSHOT</version>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.3.0.RELEASE</version>
    </parent>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
        <mybatisplus.version>3.3.2</mybatisplus.version>
        <skipTests>true</skipTests>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>
        <dependency><!--基于内存的数据库-->
            <groupId>com.h2database</groupId>
            <artifactId>h2</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>${mybatisplus.version}</version>
        </dependency>

        <dependency><!--测试框架-->
            <groupId>org.assertj</groupId>
            <artifactId>assertj-core</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency><!--简化实体类开发,加@Data注解不用写get、set方法-->
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>

    </dependencies>
</project>

4.通过工具添加启动类: 

   

5.设置配置项:(注意每一项冒号后面有个空格!)

        自动创建的配置文件为yml,和properties文件比结构层级更清晰一些:

#Datasource Configspring:spring:
spring:
  datasource:
    driver-class-name: org.h2.Driver
    schema: classpath:db/schema-h2.sql
    data: classpath:db/data-h2.sql
    #y用于测试可随便写
    url: jdbc:h2:mem:test
    username: roottest
    passworld: test123

#Logger Config
logging:
  level:
    com.lxj.quickstart: debug

6.引入测试用的数据库:

        一个是创建表的sql文件:

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)
)

        一个是插入数据的sql文件:

DELETE FROM user;

INSERT INTO user (id,name,age,email) VALUES
(1,'Jone',18,'test1@abc.com'),
(2,'Jack',19,'test2@abc.com'),
(3,'Tom',20,'test3@abc.com'),
(4,'Sandy',18,'test4@abc.com'),
(5,'hahaha',19,'test5@abc.com'),
(6,'Billie',18,'test6@abc.com');

        将两个文件放到classpath下:

        

7.编写实体类:

package com.lxj.quickstart.entity;

import lombok.Data;

@Data
public class User {

    private Long id;
    private String name;
    private  Integer age;
    private String email;

}

        @Data注解可给类中属性自动添加get/set方法。

8.编写dao类:

package com.lxj.quickstart.mapper;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.lxj.quickstart.entity.User;

public interface UserMapper extends BaseMapper<User> {

}

9.启动类中别忘了添加扫描包路径:

@MapperScan("com.lxj.quickstart.mapper")

10.添加测试类测试:

package com.lxj.quickstart.mapper;

import com.lxj.quickstart.entity.User;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;
import com.lxj.quickstart.mapper.UserMapper;
import java.util.List;

import static org.junit.Assert.*;
@RunWith(SpringRunner.class)
@SpringBootTest
public class UserMapperTest {

    @Autowired
    private UserMapper userMapper;

    @Test
    public void testSelect(){
        List<User> list = userMapper.selectList(null);
        list.forEach(System.out::println);
    }

}

11.结果:

相关推荐

  1. SpringBoot3整合MyBatisPlus

    2024-04-24 16:14:04       64 阅读
  2. Activiti7 整合SpringBoot

    2024-04-24 16:14:04       53 阅读
  3. Spring: SpringBoot MybatisPlus框架动态数据源

    2024-04-24 16:14:04       50 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-24 16:14:04       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-24 16:14:04       100 阅读
  3. 在Django里面运行非项目文件

    2024-04-24 16:14:04       82 阅读
  4. Python语言-面向对象

    2024-04-24 16:14:04       91 阅读

热门阅读

  1. VMware虚拟机经常卡死风扇狂转的解决办法

    2024-04-24 16:14:04       37 阅读
  2. ffmpeg常使用的命令

    2024-04-24 16:14:04       36 阅读
  3. 数字人成了大佬标配?再不上车就晚了

    2024-04-24 16:14:04       32 阅读
  4. 【动态规划】Leetcode 70. 爬楼梯【简单】

    2024-04-24 16:14:04       34 阅读
  5. Qt5中的常用模块

    2024-04-24 16:14:04       30 阅读
  6. 变电站综合监控系统系统组成分析

    2024-04-24 16:14:04       37 阅读
  7. 富格林:掌握鉴别阻挠虚假套路

    2024-04-24 16:14:04       32 阅读