一,初始 MyBatis-Plus

一,初始 MyBatis-Plus

文章目录

  • 一,初始 MyBatis-Plus
  • 1. MyBatis-Plus 的概述
  • 2. 入门配置第一个 MyBatis-Plus 案例
  • 3. 补充说明:
    • 3.1 通用 Mapper 接口介绍
      • 3.1.1 Mapper 接口的 “增删改查”
        • 3.1.1.1 查询所有记录
        • 3.1.1.2 插入一条数据
        • 3.1.1.3 删除一条数据
        • 3.1.1.4 更新一条数据
        • 3.1.1.5 查询一条数据
    • 3.2 通用 service接口介绍
      • 3.2.1 Service 接口的“增删改查”
        • 3.2.1.1 添加一条记录
        • 3.2.1.2 删除一条记录
        • 3.2.1.3 修改一条记录
        • 3.2.1.4 查询一条记录
    • 3.3 自定义方法
      • 3.3.1 自定义Mapper接口方法
  • 4. 总结:
  • 6. 最后:


1. MyBatis-Plus 的概述

学习 MyBatis -Plus 之前,我们可以先来简单的,稍微的,回顾一下,MyBatis 框架的一些问题:

这里只是简单的回顾,关于MyBatis 的更多详细内容大家可以移步至:✏️✏️✏️ MyBatis_ChinaRainbowSea的博客-CSDN博客

我们来简单思考一下,MyBatis 框架的开发效率怎么样?

开发效率也就是我们使用这款框架开发的速度快不快,是否简单好用易上手。从这个角度思考,每当我们需要编写一个SQL需求的时候,我们需要做几步:

  1. Mapper 接口提供一个抽象方法。
  2. Mapper 接口对应的映射配置文件提供对应的标签和SQL语句
  3. 在 Service 中依赖 Mapper 实例对象
  4. 调用 Mapper 实例中的方法
  5. 在Controller 中依赖 Service 实例对象
  6. 调用 Service 实例中的方法

通过上面的发现,对于一个SQL需求,无论是单表还是多表,我们是需要完成如上几步,才能实现SQL需求的开发。


但是在开发中,有一些操作是通过逻辑,这些通用逻辑是可以被简化的,例如:

  1. 对于 dao ,是否可以由框架帮我们提供好单表的 Mapper 抽象方法,和对应的SQL实现,不需要程序员去实现这些。
  2. 对于 service,使用可以有框架直接帮我们提供好一些 serivce 的抽象方法,和对应的实现,不需要程序员去实现这些。
  3. 一些其它的企业开发中所需要的操作

分析到这里我们发现,其实核心框架并没有发生变化,依赖还是 Mybatis,只不过我们希望对于 MyBatis 进行一些封装和优化,让他更加的好用,更加的易用。

所以:MyBatis Plus 它就来了,它是 MyBatis 的一款增强工具。

MybatisPlus,从名称上来看,我们就发现,他和Mybatis长得很像,其实MybatisPlus就是Mybatis的孪生兄弟。学习MyBatis-Plus 首先,我们来看看它的官网地址是:https://baomidou.com/

在这里插入图片描述

MyBatis-Plus (opens new window)(简称 MP)是一个 MyBatis (opens new window)的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。

愿景

我们的愿景是成为 MyBatis 最好的搭档,就像 魂斗罗 中的 1P、2P,基友搭配,效率翻倍。

在这里插入图片描述

MyBatis-Plus的特性说明:

  • 无侵入:只做增强不做改变,引入它不会对现有工程产生影响,如丝般顺滑
  • 损耗小:启动即会自动注入基本 CURD,性能基本无损耗,直接面向对象操作
  • 强大的 CRUD 操作:内置通用 Mapper、通用 Service,仅仅通过少量配置即可实现单表大部分 CRUD 操作,更有强大的条件构造器,满足各类使用需求
  • 支持 Lambda 形式调用:通过 Lambda 表达式,方便的编写各类查询条件,无需再担心字段写错
  • 支持主键自动生成:支持多达 4 种主键策略(内含分布式唯一 ID 生成器 - Sequence),可自由配置,完美解决主键问题
  • 支持 ActiveRecord 模式:支持 ActiveRecord 形式调用,实体类只需继承 Model 类即可进行强大的 CRUD 操作
  • 支持自定义全局通用操作:支持全局通用方法注入( Write once, use anywhere )
  • 内置代码生成器:采用代码或者 Maven 插件可快速生成 Mapper 、 Model 、 Service 、 Controller 层代码,支持模板引擎,更有超多自定义配置等您来使用
  • 内置分页插件:基于 MyBatis 物理分页,开发者无需关心具体操作,配置好插件之后,写分页等同于普通 List 查询
  • 分页插件支持多种数据库:支持 MySQL、MariaDB、Oracle、DB2、H2、HSQL、SQLite、Postgre、SQLServer 等多种数据库
  • 内置性能分析插件:可输出 SQL 语句以及其执行时间,建议开发测试时启用该功能,能快速揪出慢查询
  • 内置全局拦截插件:提供全表 delete 、 update 操作智能分析阻断,也可自定义拦截规则,预防误操作

MyBatis-Plus 的框架结构:

在这里插入图片描述

什么是Mybatis框架呢,他是一个持久层框架,目的是简化持久层的开发。在这里我们就使用springboot整合Mybatis,实现Mybatis框架的搭建。

特别说明:这里这个是 IDEA 2021 创建项目的操作步骤:

我们首先创建一个空的工程

在这里插入图片描述

工程名称是mp

在这里插入图片描述

创建springboot模块

在这里插入图片描述

在这里插入图片描述

这里我们选择springboot2.7.8的版本,并不勾选依赖,随后通过pom.xml手动添加

在这里插入图片描述

在这里插入图片描述




特别说明:下面这个是:IDEA 2024 的操作配置

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述


2. 入门配置第一个 MyBatis-Plus 案例

第一步: 创建数据库 mybatisplus

在这里插入图片描述

这些测试表,是来自于 MyBatis-Plus 官网教学的内容,大家也可以移步去看看:✏️✏️✏️ https://baomidou.com/getting-started/

在这里插入图片描述

现有一张 User 表,其表结构如下:

idnameageemail
1Jone18test1@baomidou.com
2Jack20test2@baomidou.com
3Tom28test3@baomidou.com
4Sandy21test4@baomidou.com
5Billie24test5@baomidou.com

其对应的数据库 Schema 脚本如下:

DROP TABLE IF EXISTS `user`;

CREATE TABLE `user`
(
    id BIGINT NOT NULL COMMENT '主键ID',
    name VARCHAR(30) NULL DEFAULT NULL COMMENT '姓名',
    age INT NULL DEFAULT NULL COMMENT '年龄',
    email VARCHAR(50) NULL DEFAULT NULL COMMENT '邮箱',
    PRIMARY KEY (id)
);

其对应的数据库 Data 脚本如下:

DELETE FROM `user`;

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

在这里插入图片描述

第二步: 引入相关依赖,在 pom.xml 文件当中配置我们所需要的 jar 依赖。

在这里插入图片描述

<?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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.5.3</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.rainbowsea</groupId>
    <artifactId>mp02</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>mp02</name>
    <description>mp02</description>
    <url/>
    <licenses>
        <license/>
    </licenses>
    <developers>
        <developer/>
    </developers>
    <scm>
        <connection/>
        <developerConnection/>
        <tag/>
        <url/>
    </scm>
    <properties>
        <java.version>8</java.version>
    </properties>
    <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>
        </dependency>


        <!--        spring boot web 依赖-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>


        <!--        mysql 驱动依赖-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>

        <!--        lombok 的依赖-->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>

        <!--        druid-->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>1.2.8</version>
        </dependency>

        <!--        mybatis-plus 的依赖-->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.4.3</version>
        </dependency>


    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
    <repositories>
        <repository>
            <id>spring-snapshots</id>
            <name>Spring Snapshots</name>
            <url>https://repo.spring.io/snapshot</url>
            <releases>
                <enabled>false</enabled>
            </releases>
        </repository>
    </repositories>
    <pluginRepositories>
        <pluginRepository>
            <id>spring-snapshots</id>
            <name>Spring Snapshots</name>
            <url>https://repo.spring.io/snapshot</url>
            <releases>
                <enabled>false</enabled>
            </releases>
        </pluginRepository>
    </pluginRepositories>

</project>

特别说明:这里我们,将 Spring boot 改为:2.5.3 版本的。在这里插入图片描述

在这里插入图片描述

在:MyBatis-Plus 当中是包含了MyBatis 的依赖的。所以,引入了 MyBatis-Plus 也就引入了MyBatis了。

在这里插入图片描述

第三步: 编写该项目/模块的场景启动器:

在这里插入图片描述

第四步: 根据数据表创建对应的实体类:

在这里插入图片描述

package com.rainbowsea.bean;

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

@Data
@NoArgsConstructor
@AllArgsConstructor
public class User {

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

第五步: 切换数据库连接池为 Druid 。这里我们编写配置类的方式,切换数据库连接池。

  1. 在 resoucre 类路径下,创建名为 applicaiton.yaml 的配置文件,其中编写连接数据库的配置信息。

在这里插入图片描述

spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:3306/mybatisplus?serverTimezone=UTC&characterEncoding=utf8&useUnicode=true&useSSL=false
    username: root
    password: MySQL123

  1. 编写配置类,切换数据库为 Druid

在这里插入图片描述

package com.rainbowsea.config;


import com.alibaba.druid.pool.DruidDataSource;

import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import javax.sql.DataSource;

/**
 * 配置切换,Druid 数据库连接池
 */
@Configuration  // 标志配置类
public class DruidDataSourceConfig {


    @Bean  // 被 Spring ioc 容器管理起来
    @ConfigurationProperties(value = "spring.datasource")
    public DataSource getDataSource() {
        DruidDataSource druidDataSource = new DruidDataSource();

        return druidDataSource;
    }
}

特别说明:关于spring boot 中切换数据库连接池的详细内容,大家可以移步至:✏️✏️✏️ 十六,Spring Boot 整合 Druid 以及使用 Druid 监控功能-CSDN博客

测试:看看我们是否成功切换为了 Druid 数据库连接池。

在这里插入图片描述



import com.rainbowsea.bean.User;
import com.rainbowsea.mapper.UserMapper;
import com.rainbowsea.service.UserService;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.jdbc.core.JdbcTemplate;

import javax.annotation.Resource;
import java.util.List;

@SpringBootTest(classes = Mp02Application.class)  // Spring Boot 当中的测试,必须要有 项目的启动场景,不然无法测试报错
class Mp02ApplicationTests {

    @Resource
    private JdbcTemplate jdbcTemplate;

    @Test
    void contextLoads() {
        System.out.println(jdbcTemplate.getDataSource().getClass());

    }
}

在这里插入图片描述

第六步: 后面的都是对应 MyBatis-Plus 的内容上的重点内容。

编写 Mapper接口

在这里插入图片描述

package com.rainbowsea.mapper;


import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.rainbowsea.bean.User;
import org.apache.ibatis.annotations.Mapper;

@Mapper // 被Spring Boot 扫描到
public interface UserMapper extends BaseMapper<User> {


}

在这里插入图片描述

在这里插入图片描述

我们的自己编写的 Mapper 接口 extends(继承) BaseMapper 接口就会拥有了其该接口下的方法。

第七步: 编写 Service 接口

在这里插入图片描述

在这里插入图片描述

package com.rainbowsea.service;

import com.baomidou.mybatisplus.extension.service.IService;
import com.rainbowsea.bean.User;

import java.util.List;

public interface UserService extends IService<User> {

    // 当 IService 当中提供的方法,不能满足我们的业务需要的时候,
    // 我们可以自定义方法。
    // 自定义的方法
    List<User> selectAll();
}

在这里插入图片描述

在这里插入图片描述

第八步: 编写ServiceImpl

在这里插入图片描述

在这里插入图片描述

package com.rainbowsea.service.Impl;

import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.rainbowsea.bean.User;
import com.rainbowsea.mapper.UserMapper;
import com.rainbowsea.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import javax.annotation.Resource;
import java.util.Collections;
import java.util.List;


@Service
public class UserServiceImpl extends ServiceImpl<UserMapper,User>
        implements UserService  {

    //@Resource
    @Autowired  // 自动装配
    private UserMapper userMapper;


    // 对自定义方法的,重写实现
    @Override
    public List<User> selectAll() {
        return userMapper.selectList(null);
    }
}

在这里插入图片描述

它们之间的关系结构如下:

在这里插入图片描述

在这里插入图片描述

**第九步:**编写Controller 控制器:

在这里插入图片描述

package com.rainbowsea.controller;


import com.rainbowsea.bean.User;
import com.rainbowsea.service.UserService;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

import javax.annotation.Resource;
import java.util.List;

@RestController
public class UserController {

    @Resource
    private UserService userService;


    @GetMapping(value = {"/selectList"})
    public List<User> selectList() {
        return userService.selectAll();
    }
}

第十一步 :打开浏览器运行测试。

在这里插入图片描述

3. 补充说明:

3.1 通用 Mapper 接口介绍

有关于 Mapper 接口,之前我们已经看到了,我们自己编写的Mapper接口继承 自己 BaseMapper 接口,由 BaseMapper 接口提供了很多单表的增删改查 相关的操作方法,在入门案例种,我们测试了查询所有的操作。我们介绍一些简单的Mapper 接口中的方法,主要是感觉一下。Mapper接口中对于单表的增删改查的操作都有涉及,更加高级的一些操作。

在这里插入图片描述

在这里插入图片描述

3.1.1 Mapper 接口的 “增删改查”

3.1.1.1 查询所有记录

在这里插入图片描述


import com.rainbowsea.bean.User;
import com.rainbowsea.mapper.UserMapper;
import com.rainbowsea.service.UserService;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.jdbc.core.JdbcTemplate;

import javax.annotation.Resource;
import java.util.List;

@SpringBootTest(classes = Mp02Application.class)  // Spring Boot 当中的测试,必须要有 项目的启动场景,不然无法测试报错
class Mp02ApplicationTests {


    @Resource
    private UserMapper userMapper;


    // 查询所有
    @Test
    void selectList() {
        List<User> users = userMapper.selectList(null);

        for (User user : users) {
            System.out.println(user);
        }
    }
}
3.1.1.2 插入一条数据

在这里插入图片描述


import com.rainbowsea.bean.User;
import com.rainbowsea.mapper.UserMapper;
import com.rainbowsea.service.UserService;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.jdbc.core.JdbcTemplate;

import javax.annotation.Resource;
import java.util.List;

@SpringBootTest(classes = Mp02Application.class)  // Spring Boot 当中的测试,必须要有 项目的启动场景,不然无法测试报错
class Mp02ApplicationTests {


    @Resource
    private UserMapper userMapper;

    // 简单添加
    @Test
    void insert() {

        User user = new User();
        user.setId(6L);
        user.setAge(18);
        user.setName("Lihua");
        user.setEmail("test6@baomidou.com");
        userMapper.insert(user);
    }
}
3.1.1.3 删除一条数据

在这里插入图片描述



import com.rainbowsea.bean.User;
import com.rainbowsea.mapper.UserMapper;
import com.rainbowsea.service.UserService;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.jdbc.core.JdbcTemplate;

import javax.annotation.Resource;
import java.util.List;

@SpringBootTest(classes = Mp02Application.class)  // Spring Boot 当中的测试,必须要有 项目的启动场景,不然无法测试报错
class Mp02ApplicationTests {


    @Resource
    private UserMapper userMapper;



    // 简单删除
    @Test
    void deleteOne() {
        userMapper.deleteById(4L);

    }

}
3.1.1.4 更新一条数据

在这里插入图片描述


import com.rainbowsea.bean.User;
import com.rainbowsea.mapper.UserMapper;
import com.rainbowsea.service.UserService;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.jdbc.core.JdbcTemplate;

import javax.annotation.Resource;
import java.util.List;

@SpringBootTest(classes = Mp02Application.class)  // Spring Boot 当中的测试,必须要有 项目的启动场景,不然无法测试报错
class Mp02ApplicationTests {
    @Resource
    private UserMapper userMapper;

    // 简单更新
    @Test
    void updateById() {
        User user = new User();
        user.setId(2L);
        user.setAge(18);
        user.setName("李华");
        user.setEmail("lihua@baomidou.com");

        userMapper.updateById(user);
    }

}
3.1.1.5 查询一条数据

在这里插入图片描述


import com.rainbowsea.bean.User;
import com.rainbowsea.mapper.UserMapper;
import com.rainbowsea.service.UserService;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.jdbc.core.JdbcTemplate;

import javax.annotation.Resource;
import java.util.List;

@SpringBootTest(classes = Mp02Application.class)  // Spring Boot 当中的测试,必须要有 项目的启动场景,不然无法测试报错
class Mp02ApplicationTests {
    @Resource
    private UserMapper userMapper;

    // 简单查询
    @Test
    void selectById() {
        User user = userMapper.selectById(6L);
        System.out.println(user);
    }

}

3.2 通用 service接口介绍

除了Mapper接口,MybatisPlus还提供了IService接口和对应的实现类ServiceImpl,该实现类已经提供好了一些对应的Service相关的方法,在某些场景下,我们可以直接使用ServiceImpl提供的方法,实现对应的功能。

IService接口
在这里插入图片描述

IService接口中包含了service相关的一些增删改查方法
在这里插入图片描述
在这里插入图片描述

ServiceImpl实现类
在这里插入图片描述

ServiceImpl实现类提供了service相关的增删改查方法的实现

在这里插入图片描述

UserService接口继承自IService接口

在这里插入图片描述

UserServiceImpl类继承ServiceImpl<UserMapper,User>
在这里插入图片描述

在这里插入图片描述

注入UserService对象,测试相关方法

在这里插入图片描述

3.2.1 Service 接口的“增删改查”

3.2.1.1 添加一条记录

在这里插入图片描述


import com.rainbowsea.bean.User;
import com.rainbowsea.mapper.UserMapper;
import com.rainbowsea.service.UserService;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.jdbc.core.JdbcTemplate;

import javax.annotation.Resource;
import java.util.List;

@SpringBootTest(classes = Mp02Application.class)  // Spring Boot 当中的测试,必须要有 项目的启动场景,不然无法测试报错
class Mp02ApplicationTests {
    @Autowired
    private UserService userService;
    
    //  UserService 添加
    @Test
    void insertService() {
        User user = new User();
        user.setId(7L);
        user.setAge(18);
        user.setName("Tom");
        user.setEmail("Tom@baomidou.com");

        userService.save(user);

    }

}
3.2.1.2 删除一条记录

在这里插入图片描述


import com.rainbowsea.bean.User;
import com.rainbowsea.mapper.UserMapper;
import com.rainbowsea.service.UserService;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.jdbc.core.JdbcTemplate;

import javax.annotation.Resource;
import java.util.List;

@SpringBootTest(classes = Mp02Application.class)  // Spring Boot 当中的测试,必须要有 项目的启动场景,不然无法测试报错
class Mp02ApplicationTests {
    @Autowired
    private UserService userService;


    // UserService 删除
    @Test
    void deleteServie() {
        userService.removeById(2L);
    }
}
3.2.1.3 修改一条记录

在这里插入图片描述


import com.rainbowsea.bean.User;
import com.rainbowsea.mapper.UserMapper;
import com.rainbowsea.service.UserService;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.jdbc.core.JdbcTemplate;

import javax.annotation.Resource;
import java.util.List;

@SpringBootTest(classes = Mp02Application.class)  // Spring Boot 当中的测试,必须要有 项目的启动场景,不然无法测试报错
class Mp02ApplicationTests {
    @Autowired
    private UserService userService;

    // userService 修改
    @Test
    void updateService() {
        User user = new User();
        user.setId(3L);
        user.setAge(22);

        userService.updateById(user);
    }


}
3.2.1.4 查询一条记录

在这里插入图片描述


import com.rainbowsea.bean.User;
import com.rainbowsea.mapper.UserMapper;
import com.rainbowsea.service.UserService;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.jdbc.core.JdbcTemplate;

import javax.annotation.Resource;
import java.util.List;

@SpringBootTest(classes = Mp02Application.class)  // Spring Boot 当中的测试,必须要有 项目的启动场景,不然无法测试报错
class Mp02ApplicationTests {
    @Autowired
    private UserService userService;



    // UserService 查询
    @Test
    void selectService() {
        List<User> users = userService.selectAll();
        for (User user : users) {
            System.out.println(user);
        }
    }
}

3.3 自定义方法

MybatisPlus除了给我们提供了这些丰富的接口方法以外,对于我们自己的需求,也可以编写自定义的接口方法,我们通过自己编写SQL语句的形式,实现想要的SQL需求

3.3.1 自定义Mapper接口方法

Mapper接口中提供抽象方法

在这里插入图片描述

package com.rainbowsea.mapper;


import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.rainbowsea.bean.User;
import org.apache.ibatis.annotations.Mapper;

@Mapper // 被Spring Boot 扫描到
public interface UserMapper extends BaseMapper<User> {

    // 自定义方法
  User selectByName(String name);

}

提供映射配置文件,提供对应的SQL语句

注意:对应的映射的 SQL 配置文件的路径/包要一致,以及名称也要一致,才行。

在这里插入图片描述

在这里插入图片描述

<?xml version="1.0" encoding="UTF-8"?> <!-- 这句不要动,表示xml的版本,以及读取的编码 -->

<!DOCTYPE mapper
		PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
		"http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<mapper namespace="com.rainbowsea.mapper.UserMapper" >

	<select id="selectByName" resultType="com.rainbowsea.bean.User" parameterType="string">
		select id,age,name,email
		from user
		where name = #{value}

	</select>
</mapper>

测试自定义的Mapper接口方法

在这里插入图片描述


import com.rainbowsea.bean.User;
import com.rainbowsea.mapper.UserMapper;
import com.rainbowsea.service.UserService;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.jdbc.core.JdbcTemplate;

import javax.annotation.Resource;
import java.util.List;

@SpringBootTest(classes = Mp02Application.class)  // Spring Boot 当中的测试,必须要有 项目的启动场景,不然无法测试报错
class Mp02ApplicationTests {

    @Resource
    private UserMapper userMapper;


    // 测试自定义方法
    @Test
    void myMethod() {
        User tom = userMapper.selectByName("Lihua");
        System.out.println(tom);
    }
}

4. 总结:

  1. MyBatis-Plus官网地址:https://baomidou.com/
  2. MyBatis-Plus (opens new window)(简称 MP)是一个 MyBatis (opens new window)的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。
  3. 记忆理解 MyBatis-Plus 内置的 Mapper 接口,和 Service 接口

在这里插入图片描述

在这里插入图片描述

6. 最后:

“在这个最后的篇章中,我要表达我对每一位读者的感激之情。你们的关注和回复是我创作的动力源泉,我从你们身上吸取了无尽的灵感与勇气。我会将你们的鼓励留在心底,继续在其他的领域奋斗。感谢你们,我们总会在某个时刻再次相遇。”

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/883078.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

LeetCode[中等] 155. 最小栈

设计一个支持 push &#xff0c;pop &#xff0c;top 操作&#xff0c;并能在常数时间内检索到最小元素的栈。 实现 MinStack 类: MinStack() 初始化堆栈对象。void push(int val) 将元素val推入堆栈。void pop() 删除堆栈顶部的元素。int top() 获取堆栈顶部的元素。int get…

【html网页制作】旅游风景主题网页制作含css动画及js特效(8页面附效果源码)

HTMLCSS旅游风景主题旅游网页制作 &#x1f354;涉及知识&#x1f964;写在前面&#x1f367;一、网页主题&#x1f333;二、网页效果菜单切换效果PageA、整体页Page1、首页Page2、旅行趣事页Page3、旅行美景页Page4、旅行指南页Page5、旅行视频页Page6、留言页Page7、西湖简介…

python-比较月亮大小/数组下标/人见人爱a+b

一:比较月亮大小 题目描述 小理是一名出色的狼人。众所周知&#xff0c;狼人只有在满月之夜才会变成狼。 同时&#xff0c;月亮的大小随着时间变化&#xff0c;它的大小变化 3030 天为一循环。 它的变化情况(从第一天开始)为 0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,14,13,12,1…

深度学习之概率论预备知识点(3)

在深度学习中&#xff0c;概率论和数理统计是理解许多算法背后的理论基础。这些知识在处理不确定性、估计模型参数、理解数据分布等方面非常关键 1、概率 一种用来描述随机事件发生的可能性的数字度量&#xff0c;表示某一事件发生的可能性。 概率并不客观存在&#xff0c;是…

华为云centos7.9按装ambari 2.7.5 hostname 踩坑记录

华为云centos7.9按装ambari 2.7.5踩坑记录 前言升华总结 前言 一般都是废话&#xff0c;本人专业写bug业余运维。起初找了三台不废弃的台式机&#xff0c;开始重装centos系统&#xff0c;开始了HDP3.1.5Ambari2.7.5安装。 推荐一波好文&#xff0c;一路长绿。跑了一段时间没啥…

学习国语的时候需要用到什么翻译工具?《维汉翻译通》app现在已经支持国语拼音和维汉词典查单词功能

《维汉翻译通》App是一款免费的翻译工具&#xff0c;专为维吾尔语与中文之间的沟通设计。它不仅是一款翻译应用&#xff0c;也是新疆人学习中文的得力助手。 功能亮点 免费翻译服务&#xff1a;提供快速准确的短文本翻译&#xff0c;无论是日常用语还是专业术语。智能OCR技术&…

mysql批量修改表前缀

现有表前缀xh,批量修改为fax_需要怎么做 SELECTCONCAT(ALTER TABLE ,table_name, RENAME TO fax_,substring(table_name, 3),;) FROMinformation_schema. TABLES WHEREtable_name LIKE xh_%; 运行之后可以但是生成了一批修改表明的命令 此时批量复制执行就可实现批量修改表前…

基于Node.js+Express+MySQL+VUE新闻网站管理系统的设计与实现

1. 引言 随着互联网技术的发展&#xff0c;人们获取信息的方式发生了巨大的变化。传统的新闻媒体逐渐向数字化、智能化方向发展。新闻推荐网站管理系统能够帮助新闻网站更好地管理和推荐新闻内容&#xff0c;提高用户体验。本文将详细介绍一个新闻推荐网站管理系统的整体设计与…

申论笔记杉树林

同义词尽量用文章中的词进行拼凑不一定要有前置词分条 单一题 同义词给分不一定需要前置词分条 1、2、3、尽量抄文章中的词&#xff0c;通顺即可&#xff0c;不一定要成句子不要过分关注形式 题干&#xff1a; 条理清晰&#xff1a;要求分条&#xff0c;尽量有提示词…

Python网络爬虫获取Wallhaven壁纸图片(源码)

** 话不多说&#xff0c;直接附源码&#xff0c;可运行&#xff01; ** import requests from lxml import etree from fake_useragent import UserAgent import timeclass wallhaven(object):def __init__(self):# yellow# self.url "https://wallhaven.cc/search?co…

浙大数据结构:05-树8 File Transfer

数据结构MOOC PTA习题 这道题考察并查集的操作&#xff0c;合并以及找根结点 机翻&#xff1a; 1、条件准备 node是数组存放1-N结点的根节点的&#xff0c;n为总结点数 #include <iostream> using namespace std;const int N 1e4 5; int node[N]; int n; 先初始化…

C++ | Leetcode C++题解之第420题强密码检验器

题目&#xff1a; 题解&#xff1a; class Solution { public:int strongPasswordChecker(string password) {int n password.size();bool has_lower false, has_upper false, has_digit false;for (char ch: password) {if (islower(ch)) {has_lower true;}else if (isu…

华为HarmonyOS灵活高效的消息推送服务(Push Kit) -- 10 推送实况窗消息

场景介绍 实况窗是一种帮助用户聚焦正在进行的任务&#xff0c;方便快速查看和即时处理的通知形态。有关实况窗简介、权限申请、开放场景、设计规范等说明&#xff0c;请参见Live View Kit简介。 通过Push Kit发送的实况窗消息支持三种操作类型&#xff0c;分别是&#xff1a…

可变剪接分析一步到位,这个 R 包够猛!

生信碱移 ASpediaFI可变剪接 可变剪接&#xff08;Alternative Splicing, AS&#xff09;是基因表达过程中一种重要的调控机制&#xff0c;通过这种机制&#xff0c;单个基因可以产生多个不同的mRNA转录本&#xff0c;这些转录本通过不同的剪接方式&#xff08;即选择性地包括…

Vue使用axios二次封装、解决跨域问题

1、什么是 axios 在实际开发过程中&#xff0c;浏览器通常需要和服务器端进行数据交互。而 Vue.js 并未提供与服务器端通信的接口。从 Vue.js 2.0 版本之后&#xff0c;官方推荐使用 axios 来实现 Ajax 请求。axios 是一个基于 promise 的 HTTP 客户端。 关于 promise 的详细介…

AGV小车全双工通信应用-低延迟、8路并发全双工通信

随着智能制造和物流行业的不断发展&#xff0c;AGV小车&#xff08;自动导引车&#xff09;在工厂、仓库、物流中心的应用日益广泛。AGV小车凭借其自动化、高效、灵活的特点&#xff0c;逐渐成为物料搬运中的关键设备。在这种复杂多变的环境中&#xff0c;数据传输的可靠性、实…

c语言200例 063 信息查询

大家好&#xff0c;欢迎来到无限大的频道。 今天给大家带来的是c语言200例 题目要求&#xff1a; 从键盘当中输入姓名和电话号&#xff0c;以“#”结束&#xff0c;编程实现输入姓名、查询电话号的功能。 参考代码如下&#xff1a; #include <stdio.h> #include <st…

计算机视觉的应用34-基于CV领域的人脸关键点特征智能提取的技术方法

大家好&#xff0c;我是微学AI&#xff0c;今天给大家介绍一下计算机视觉的应用34-基于CV领域的人脸关键点特征智能提取的技术方法。本文主要探讨计算机视觉领域中人脸关键点特征智能提取的技术方法。详细介绍了基于卷积神经网络模型进行人脸关键点提取的过程&#xff0c;包括使…

css-functions伪类选择器系列二

一张图浏览CSS Functions 概述 本文主要讲述CSS的部分伪类选择器第二篇,包括::nth-child、:nth-last-child、:nth-of-type和:nth-last-of-type。 :nth-child() :nth-child伪类是根据父元素的子元素列表中的索引来选择元素。 语法 :nth-child是以一个参数nth来描述匹配兄…

apache paimon简介(官翻)

介绍 如下架构所示: 读/写操作: Paimon 支持多样化的数据读写方式,并支持 OLAP 查询。 读取: 支持从历史快照(批处理模式)中消费数据,从最新偏移量(流处理模式)中读取数据,或以混合方式读取增量快照。写入: 支持从数据库变更日志(CDC)进行流式同步,从离线数据中…