当前位置: 首页 > news >正文

一,初始 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.Driverurl: jdbc:mysql://localhost:3306/mybatisplus?serverTimezone=UTC&characterEncoding=utf8&useUnicode=true&useSSL=falseusername: rootpassword: 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 {@Resourceprivate JdbcTemplate jdbcTemplate;@Testvoid 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;// 对自定义方法的,重写实现@Overridepublic 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 {@Resourceprivate 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 {@Resourceprivate UserMapper userMapper;// 查询所有@Testvoid 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 {@Resourceprivate UserMapper userMapper;// 简单添加@Testvoid 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 {@Resourceprivate UserMapper userMapper;// 简单删除@Testvoid 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 {@Resourceprivate UserMapper userMapper;// 简单更新@Testvoid 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 {@Resourceprivate UserMapper userMapper;// 简单查询@Testvoid 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 {@Autowiredprivate UserService userService;//  UserService 添加@Testvoid 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 {@Autowiredprivate UserService userService;// UserService 删除@Testvoid 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 {@Autowiredprivate UserService userService;// userService 修改@Testvoid 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 {@Autowiredprivate UserService userService;// UserService 查询@Testvoid 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 mapperPUBLIC "-//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,emailfrom userwhere 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 {@Resourceprivate UserMapper userMapper;// 测试自定义方法@Testvoid 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. 最后:

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

在这里插入图片描述

相关文章:

一,初始 MyBatis-Plus

一&#xff0c;初始 MyBatis-Plus 文章目录 一&#xff0c;初始 MyBatis-Plus1. MyBatis-Plus 的概述2. 入门配置第一个 MyBatis-Plus 案例3. 补充说明&#xff1a;3.1 通用 Mapper 接口介绍3.1.1 Mapper 接口的 “增删改查”3.1.1.1 查询所有记录3.1.1.2 插入一条数据3.1.1.3 …...

安卓13删除下拉栏中的关机按钮版本2 android13删除下拉栏关机按钮

总纲 android13 rom 开发总纲说明 文章目录 1.前言2.问题分析3.代码分析4.代码修改5.编译6.彩蛋1.前言 顶部导航栏下拉可以看到,底部这里有个设置按钮,点击可以进入设备的设置页面,这里我们将更改为删除,不同用户通过这个地方进入设置。我们之前写过一个文章也是一样的删除…...

快递物流单号识别API接口代码

官网&#xff1a;快递鸟 API参数 一、接口描述/说明 &#xff08;1&#xff09;该接口仅对运单号做出识别&#xff0c;识别可能属于的一家或多家快递公司。 &#xff08;2&#xff09;接口并不返回物流轨迹&#xff0c;用户可结合即时查询接口和订阅查询接口完成轨迹查询、订…...

AI时代的程序员:如何保持和提升核心竞争力

1.引言 随着AIGC&#xff08;如 ChatGPT、Midjourney、Claude 等&#xff09;大语言模型的快速崛起&#xff0c;AI辅助编程工具逐渐成为程序员工作的重要组成部分。这一转变不仅改变了工作方式&#xff0c;更深刻影响了程序员的职业角色和技术路径。有人担心&#xff0c;AI将取…...

Oracle 数据库常用命令与操作指南

Oracle 数据库是企业级系统中常用的数据库管理系统&#xff0c;掌握基础的命令可以让你在日常管理中更加高效。本指南将介绍几条常用的 Oracle 数据库命令&#xff0c;涵盖用户权限管理、修改用户密码、删除用户、以及其他日常操作。 目录 授权用户操作权限使用最高权限登录 O…...

spring boot项目对接人大金仓

先确认一下依赖 第一 是否引入了mybatis-plus多数据源&#xff0c;如果引入了请将版本保持在3.5.0以上 <dependency><groupId>com.baomidou</groupId><artifactId>dynamic-datasource-spring-boot-starter</artifactId><version>${dynam…...

《操作系统 - 清华大学》1 -2:操作系统概述 —— 什么是操作系统

文章目录 1. 操作系统定义2. 操作系统的位置3. 操作系统软件的分类4. 操作系统软件的组成5. 操作系统内核特征 现在来继续讲什么是操作系统&#xff0c;操作系统什么样的&#xff1f;它是一个程序&#xff0c;它和其他程序是什么样的关系&#xff1f;然后它有些什么样的组成&am…...

power bi制作各季度收入累加柱状图——日期表、calculate、datesytd

一、数据介绍&#xff1a; 2017-2019年订单销售收入数据&#xff08;订单日期&#xff0c;销售收入&#xff09; 二、效果展示&#xff1a; 三、操作步骤&#xff1a; 1、建立日期表 &#xff08;1&#xff09;建立原因 本次度量值编写需要运用到datesytd这一时间智能函数…...

OceanBase 3.X 高可用 (一)

OceanBase 3.X 高可用&#xff08;一&#xff09; 一、分布式核心 OceanBase 3.x 采用的是paxos 协议&#xff0c;与raft协议相比。其复杂程度高&#xff0c;实现技术难度大。 Paxos 协议允许事务日志乱序发送&#xff0c;顺序提交。raft允许事务顺序发送&#xff0c;顺序提…...

CSR、SSR、SSG

客户端渲染&#xff08;Client-Side Rendering, CSR&#xff09;在SEO方面存在一些不利因素&#xff0c;主要原因包括&#xff1a; 初始加载内容的缺乏&#xff1a;CSR依赖于JavaScript来动态生成页面内容。当搜索引擎爬虫访问一个使用CSR技术构建的网站时&#xff0c;它们最初…...

linux -L16-linux 查看应用占用的资源top

linux 查看应用占用的资源top Targetsteps启动 top 命令排序进程&#xff1a;查看特定进程&#xff1a;过滤进程其他常用选项交互式帮助 Target linux 查看应用占用的资源top steps 在 Linux 系统中&#xff0c;top 命令是一个非常有用的工具&#xff0c;它提供了一个实时更…...

QT——多线程操作

一、单线程和多线程的区别 单线程指的是程序在执行时只有一个流程,也就是一次只能执行一个任务。当程序中某个任务需要花费大量时间时,单线程会导致整个程序阻塞,用户体验会变差。 多线程则是指程序在执行时可以同时执行多个任务,每个任务都是一个独立的线程。多线程可以…...

理解C语言之深入理解指针(三)

目录 1. 字符指针变量 2. 数组指针变量 2.1 数组指针变量是什么&#xff1f; 2.2 数组指针变量怎么初始化 3. ⼆维数组传参的本质 4. 函数指针变量 4.1 函数指针变量的创建 4.2 函数指针变量的使⽤ 4.3 两段有趣的代码 4.3.1 typedef 关键字 5. 函数指针数组 6. 转移…...

「芯片知识」MP3解码ic方案,音乐芯片在数字音频中的作用

MP3解码芯片是一种由内部晶振器组成的简单语音电路&#xff0c;将这种独特的MP3音乐芯片与其他零件进行接驳&#xff0c;便能够形成一个完整的语音集成电路。而深受顾客欢迎的MP3音乐芯片现如今已经广泛的使用在电子玩具和家用电器等众多的场合之中&#xff0c;它在数字音频中扮…...

MyBatis与 Springboot 的集成

MyBatis 是一个优秀的持久层框架&#xff0c;专注于 SQL 语句的灵活控制&#xff0c;与 Spring Boot 集成可以简化数据库操作&#xff0c;提升开发效率。Spring Boot 提供了与 MyBatis 无缝集成的支持&#xff0c;使得 MyBatis 可以轻松与 Spring Boot 应用结合使用。 一、MyB…...

迁移学习和外推关系

**迁移学习&#xff08;Transfer Learning&#xff09;和外推&#xff08;Extrapolation&#xff09;**都是机器学习中处理新数据的一种方式&#xff0c;但它们的定义、应用场景和挑战有所不同。让我们来对比两者并探讨它们的关系。 定义 迁移学习&#xff08;Transfer Learni…...

小程序-生命周期与WXS脚本

生命周期 什么是生命周期 生命周期&#xff08;Life Cycle&#xff09;是指一个对象从创建 -> 运行 -> 销毁的整个阶段&#xff0c;强调的是一个时间段。 我们可以把每个小程序运行的过程&#xff0c;也概括为生命周期&#xff1a; 小程序的启动&#xff0c;表示生命…...

828华为云征文 | 云服务器Flexus X实例,Docker集成搭建FC-web模拟器

828华为云征文 | 云服务器Flexus X实例&#xff0c;Docker集成搭建FC-web模拟器 华为云端口放行 服务器放行对应端口9995 Docker安装并配置镜像加速 1、购买华为云 Flexus X 实例 Flexus云服务器X实例-华为云 (huaweicloud.com) 2、docker安装 yum install -y docker-ce3、验证…...

_RET_IP_ 和_THIS_IP_ 作用

在Linux内核中,有两个罕见的宏定义_RET_IP_ 和_THIS_IP_。但是这两个宏在内核代码中又时不时的出现&#xff0c;那么它们到底是什么含义呢? 1、宏定义 我们先看它们的宏定义 include./linux/kernel.h#define _RET_IP_ (unsigned long)__builtin_return_address(0)#define …...

Spring Boot 点餐系统:高效餐饮服务

第二章关键技术的研究 2.1相关技术 网上点餐系统是在Java MySQL开发环境的基础上开发的。Java是一种服务器端脚本语言&#xff0c;易于学习&#xff0c;实用且面向用户。全球超过35&#xff05;的Java驱动的互联网站点使用Java。MySQL是一个数据库管理系统&#xff0c;因为它的…...

RtspServer:轻量级RTSP服务器和推流器

文章目录 项目概述技术分析支持的编码格式传输方式心跳检测机制RTSP 推流安全性 架构分析RtspServer 整体架构流程分析1. 客户端连接和会话建立2. 媒体数据传输3. 心跳检测和连接维护 xop 基础库项目介绍功能特性xop 整体架构 应用场景社区问题收集与解答问题一&#xff1a;刚开…...

为什么结构化 Prompt 如此有效?

你好&#xff0c;我是三桥君 在今年&#xff0c;我研究了结构化编写Prompt的方法&#xff0c;并观察到这种结构化、模板化的Prompt能够有效地突破ChatGPT 3.5的限制&#xff0c;实现所谓的“越狱”。然而&#xff0c;为什么ChatGPT会对这种结构化Prompt如此有效呢&#xff1f;…...

无人机飞手培训校企合作特训技术详解

随着无人机技术的飞速发展&#xff0c;其在航拍、农业、测绘、救援等多个领域的应用日益广泛&#xff0c;市场对高素质无人机飞手的需求急剧增加。为满足这一需求&#xff0c;促进教育与产业深度融合&#xff0c;无人机飞手培训校企合作模式应运而生。本文将从确定合作目标、共…...

从零开始的软件开发详解:数字药店系统源码与医保购药APP

很多小伙伴们疑问&#xff0c;医保购药APP是如何开发的&#xff0c;今天我将从零数字药店系统源码开始为大家提供一条清晰的实现方案。 一、技术架构设计 在开发医保购药APP之前&#xff0c;首先需要明确技术架构。一般来说&#xff0c;APP的技术架构可以分为前端和后端。 1…...

【记录】在返回值类型为BigDecimal情况下末尾小数位为0的会省略不显示

【问题】&#xff1a;在返回值类型为BigDecimal情况下末尾小数位为0的会省略不显示 问题复现&#xff1a; 实体类 package com.zlp.aspect.entity;import java.math.BigDecimal;/*** program: my_utils* description:* author: zlp* create: 2024-09-24 10:01**/public clas…...

通信工程高级职称评审条件详细解读

通信工程只有正高和副高级别的职称&#xff0c;中级通信工程的职称是需要自己参加考试的&#xff0c;并不是评审获得&#xff0c;这个大家需要注意一下&#xff0c;先要考取中级通信工程师之后才能评审副高和正高级通信工程的职称。 下面跟甘建二一起来看看通信专业职称评审条件…...

yolov8环境安装

yolov8 git地址 https://github.com/ultralytics/ultralytics/tree/main 我的电脑显卡配置 nvidia-smi cuda11.8下载 https://developer.nvidia.com/cuda-11-8-0-download-archive?target_osWindows&target_archx86_64&target_version10&target_typeexe_local …...

C语言中易混淆概念的关键字

最快的关键字---- register register&#xff1a; 这个关键字请求编译器尽可能的将变量存在 CPU 内部寄存器中而不是通过内 存寻址访问以提高效率。注意是尽可能&#xff0c;不是绝对。你想想&#xff0c;一个 CPU 的寄存器也就那么 几个或几十个&#xff0c;你要是定义了很多很…...

网络资源模板--Android Studio 零食工坊(商城)

目录 一、项目演示 二、项目测试环境 三、项目详情 四、完整的项目源码 一、项目演示 网络资源模板--零食工坊 二、项目测试环境 三、项目详情 1. **加载 Fragment 布局**&#xff1a; - 使用 inflater.inflate 加载 fragment_snack 的布局。 2. **视图组件初始化**&am…...

百度高德坐标系相互转换

一、百度与高德坐标系互换 百度坐标系&#xff1a;bd09 高德坐标系&#xff1a; gcj02 import math# 坐标系转换&#xff1a;百度转高德&#xff0c;高德转百度 class CoordinateSystem:staticmethoddef bd09_to_gcj02(bd_lon, bd_lat):百度坐标系:bd09 转成高德坐标系 gcj0…...