当前位置: 代码网 > it编程>编程语言>Java > SpringBoot整合MybatisPlus的基本应用指南

SpringBoot整合MybatisPlus的基本应用指南

2025年03月23日 Java 我要评论
一、mybatisplus简介先来看一下官方的简介吧。mybatis-plus (简称 mp)是一个 mybatis的增强工具,在 mybatis 的基础上只做增强不做改变,为 简化开发、提高效率而生

一、mybatisplus简介

先来看一下官方的简介吧。

mybatis-plus (简称 mp)是一个 mybatis的增强工具,在 mybatis 的基础上只做增强不做改变,为 简化开发、提高效率而生。mybatis-plus提供了通用的mapper和service,可以在不编写任何sql语句的前提下,快速的实现单表的增删改查(curd),批量,逻辑删除,分页等操作。只要把mybatis-plus的特性到优秀插件,以及多数据源的配置进行详细讲解。

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

mybatisplus的特性 

无侵入:只做增强不做改变,引入它不会对现有工程产生影响,如丝般顺滑

损耗小:启动即会自动注入基本 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 操作智能分析阻断,也可自定义拦截规则,预防误操作

想要更多的了解mybatisplus,可以到官网去看一下 mybatis-plus (baomidou.com)

我们直接上手讲解springboot项目如何整合mybatisplus。

二、springboot整合mybatisplus

1、创建数据库和表

create database `mybatis_plus` /*!40100 default character set 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;

2.添加数据

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

3.创建一个springboot项目

因为我没有配置阿里的服务器,所以创建的springboot项目没有java8版本,我是后期自己修改的,并且使用springboot2.7.16版本,大家可以配置一下服务器url。之后就可以创建8版本了。

https://start.aliyun.com

项目结构。 我把application.properties文件修改为了yml格式。

4.导入依赖

如果想要使用lombok插件需要在设置中找到插件,下载lombok插件。lombok可以简化我们的开发。

        <dependency>
            <groupid>com.baomidou</groupid>
            <artifactid>mybatis-plus-boot-starter</artifactid>
            <version>3.5.2</version>
        </dependency>
        <dependency>
            <groupid>org.projectlombok</groupid>
            <artifactid>lombok</artifactid>
        </dependency>
        <dependency>
            <groupid>mysql</groupid>
            <artifactid>mysql-connector-java</artifactid>
            <version>5.1.5</version>
        </dependency>

创建我们需要的包。

5.修改application.yml文件

这里的密码需要根据你自己的情况修改。

spring:
  # 配置数据源信息
  datasource:
  # 配置连接数据库信息
    driver-class-name: com.mysql.jdbc.driver
    url: jdbc:mysql://localhost:3306/mybatis_plus?characterencoding=utf-8&usessl=false
    username: root
    password: 2020

6.创建实体user的类 

在domain目录下创建user类。

@data
public class user {
    //设定id自增
    @tableid(type = idtype.auto)
    private integer id;
    private string name;
    private integer age;
    private string email;
}

7.添加mapper

在mapper目录下创建usermapper。usermapper继承basemapper,basemapper中封装着一些基本的增删改查操作,这样就不用我们在自己写dao层了。

@mapper
public interface usermapper extends basemapper<user> {
}

三、基本的crud操作 

我们在test方法中实现测试。

1.查询所有用户

调用selectlist()方法,方法需要传入一个参数querywrapper,querywrapper相当于sql语句中的一些限制条件(这里不必在意我的输出结果,数据库的表格我已经变动过了,大家只要有输出即可)。

@test
    void getalluser(){
        list<user> users = usermapper.selectlist(null);
        for (user user : users) {
            system.out.println(user);
        }
    }

2.插入用户 

这里可能会报错,提示id不存在,我们要把数据库当中的id字段改为自动递增。

 @test
    public void testinsert(){
        user user = new user(null, "哈__", 23, "ha@test.com");
        //insert into user ( id, name, age, email ) values ( ?, ?, ?, ? )
        int result = usermapper.insert(user);
        system.out.println("受影响行数:"+result);
        system.out.println("id自动获取:"+user.getid());
    }

3.删除用户 

@test
    public void testdeletebyid(){
        //通过id删除用户信息
        //delete from user where id=?
        int result = usermapper.deletebyid(9);
        system.out.println("受影响行数:"+result);
    }

4.更新用户 

根据传入的user的id更新,如果user中的某些字段为null,那么mybatisplus不会把值为null的属性向数据库进行更新。

@test
    public void testupdatebyid(){
        user user = new user(1, "admin", 22, null);
        //update user set name=?, age=? where id=?
        int result = usermapper.updatebyid(user);
        system.out.println("受影响行数:"+result);
    }

5.添加mybatisplus日志

在application.yml文件当中写入如下配置。

mybatis-plus:
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.stdoutimpl

 看效果。

四、service封装mapper

在service包下创建iuserservice接口。并创建impl包,在service.impl包下创建userserviceimpl。

public interface iuserservice extends iservice<user> {
}
@service
public class userserviceimpl extends serviceimpl<usermapper, user> implements iuserservice{
}

通过service调用mapper。mybatisplus官方已经帮我们封装好了。

1.查询所有用户

 @resource
    userserviceimpl userservice;
    @test
    void getalluser(){
        list<user> users = userservice.list();
        for (user user : users) {
            system.out.println(user);
        }
    }

其他的就不在展示了,大家可以自己探索一下。 

 五、basemapper常用方法

package com.baomidou.mybatisplus.core.mapper;
 
public interface basemapper<t> extends mapper<t> {
 
/**
* 插入一条记录
* @param entity 实体对象 */
int insert(t entity);
 
/**
* 根据 id 删除
* @param id 主键id */
int deletebyid(serializable id);
 
/**
* 根据实体(id)删除
* @param entity 实体对象
* @since 3.4.4 */
int deletebyid(t entity);
 
/**
* 根据 columnmap 条件,删除记录
* @param columnmap 表字段 map 对象 */
int deletebymap(@param(constants.column_map) map<string, object> columnmap);
 
/**
* 根据 entity 条件,删除记录
* @param querywrapper 实体对象封装操作类(可以为 null,里面的 entity 用于生成 where
语句)
*/
int delete(@param(constants.wrapper) wrapper<t> querywrapper);
 
/**
* 删除(根据id 批量删除)
* @param idlist 主键id列表(不能为 null 以及 empty) */
int deletebatchids(@param(constants.collection) collection<? extends serializable> idlist);
 
/**
* 根据 id 修改
* @param entity 实体对象 */
int updatebyid(@param(constants.entity) t entity);
 
/**
* 根据 whereentity 条件,更新记录
* @param entity        实体对象 (set 条件值 ,可以为 null)
* @param updatewrapper 实体对象封装操作类(可以为 null,里面的 entity 用于生成
where 语句)
*/
int update(@param(constants.entity) t entity, @param(constants.wrapper) wrapper<t> updatewrapper);
 
/**
* 根据 id 查询
* @param id 主键id */
t selectbyid(serializable id);
 
/**
* 查询(根据id 批量查询)
* @param idlist 主键id列表(不能为 null 以及 empty) */
list<t> selectbatchids(@param(constants.collection) collection<? extends serializable> idlist);
 
/**
* 查询(根据 columnmap 条件)
* @param columnmap 表字段 map 对象 */
list<t> selectbymap(@param(constants.column_map) map<string, object> columnmap);
 
/**
* 根据 entity 条件,查询一条记录
* <p>查询一条记录,例如 qw.last("limit 1") 限制取一条记录 , 注意:多条数据会报异常 </p>
* @param querywrapper 实体对象封装操作类(可以为 null)
*/
default t selectone(@param(constants.wrapper) wrapper<t> querywrapper) { list<t> ts = this.selectlist(querywrapper);
if (collectionutils.isnotempty(ts)) {
if (ts.size() != 1) {
throw exceptionutils.mpe("one record is expected, but the query result is multiple records");
}
return ts.get(0);
}
return null;
}
 
/**
* 根据 wrapper 条件,查询总记录数
* @param querywrapper 实体对象封装操作类(可以为 null) */
long selectcount(@param(constants.wrapper) wrapper<t> querywrapper);
 
/**
* 根据 entity 条件,查询全部记录
* @param querywrapper 实体对象封装操作类(可以为 null) */
list<t> selectlist(@param(constants.wrapper) wrapper<t> querywrapper);
 
/**
* 根据 wrapper 条件,查询全部记录
* @param querywrapper 实体对象封装操作类(可以为 null) */
list<map<string, object>> selectmaps(@param(constants.wrapper) wrapper<t> querywrapper);
 
/**
* 根据 wrapper 条件,查询全部记录
* <p>注意: 只返回第一个字段的值</p>
* @param querywrapper 实体对象封装操作类(可以为 null) */
list<object> selectobjs(@param(constants.wrapper) wrapper<t> querywrapper);
 
/**
* 根据 entity 条件,查询全部记录(并翻页)
* @param page         分页查询条件(可以为 rowbounds.default)
* @param querywrapper 实体对象封装操作类(可以为 null) */
<p extends ipage<t>> p selectpage(p page, @param(constants.wrapper) wrapper<t> querywrapper);
 
/**
* 根据 wrapper 条件,查询全部记录(并翻页)
* @param page         分页查询条件
* @param querywrapper 实体对象封装操作类 */
<p extends ipage<map<string, object>>> p selectmapspage(p page, @param(constants.wrapper) wrapper<t> querywrapper);

以上就是springboot整合mybatisplus的基本应用指南的详细内容,更多关于springboot整合mybatisplus的资料请关注代码网其它相关文章!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com