mybatisplus 入门

本文详细介绍了如何使用SpringBoot和MyBatis-Plus进行数据库操作,包括创建数据库表、数据插入、查询、更新和删除,以及通用Service的封装。通过实例演示了如何使用lombok和MapperScan进行简化开发过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. 数据准备

在本地创建数据库 mybatis_plus

CREATE DATABASE `mybatis_plus` /*!40100 DEFAULT CHARACTER SET utf8mb4 */;

数据库中创建表 user

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;

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

2.通过 Idea 生成一个 springboot 项目

pom.xml 配置如下

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

        <!-- mybatis 启动类-->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.5.1</version>
        </dependency>
        <!-- 通过注解生成 get set 构造函数等方法-->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <!-- mysql驱动  这里用的是 springboot 自带的驱动-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>
        <!-- 阿里数据库连接池 -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid-spring-boot-starter</artifactId>
            <version>1.2.8</version>
        </dependency>

</dependencies>

application.yml 配置如下:

spring:
  datasource:
    # 配置数据源类型
    type: com.alibaba.druid.pool.DruidDataSource
    # 配置连接数据库信息
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:3306/mybatis_plus?characterEncoding=utf-8&useSSL=false
    username: root
    password: root

创建实体类 User

import lombok.Data;

@Data //lombok注解 生成get set 构造方法等
public class User {
    private Long id;
    private String name;
    private Integer age;
    private String email;
}

创建 UserMapper

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.zym.mybatisplus.domain.User;
import org.springframework.stereotype.Repository;

@Repository
public interface UserMapper extends BaseMapper<User> {
}

主启动类添加 @MapperScan ,详细如下

/**
 * @MapperScan 扫描 mapper 包,我的包是com.zym.mybatisplus.mapper,你们改成自己的包哈
 */
@SpringBootApplication
@MapperScan("com.zym.mybatisplus.mapper")
public class MybatisplusApplication {

    public static void main(String[] args) {
        SpringApplication.run(MybatisplusApplication.class, args);
    }

}

3.测试 

@SpringBootTest
class MybatisplusApplicationTests {

    @Autowired
    private UserMapper userMapper;

    @Test
    public void testSelectList(){
        // 查询user表中的所有数据
        List<User> users = userMapper.selectList(null);
        // 遍历打印 user 表中的数据
        for (User user : users) {
            System.out.println(user.toString());
        }
    }

}

结果打印出数据库中的五条数据

4.其它方法测试

4.1 新增方法

@Test
    public void testInsert()
    {
        User user = new User();
        user.setAge(30);
        user.setName("赵义明");
        user.setEmail("824898869@qq.com");
        // insert 方法返回的是影响行数
        int result = userMapper.insert(user);
        System.out.println("影响行数:"+result);
        // mybatisplus 帮我们新增数据会不会返回ID呢? 看运行结果,答案是会返回新数据的ID
        System.out.println("user对象ID:"+user.getId());
    }

结果

 4.2 删除方法

@Test
    public void testDelete()
    {
        // 根据ID删除数据
        int result1 = userMapper.deleteById(1548946947622506497L);
        System.out.println("影响的行数:"+result1);

        // 根据条件删除
        Map<String,Object> map = new HashMap<String,Object>();
        map.put("age",24);
        map.put("name","Billie");
        int result2 = userMapper.deleteByMap(map);
        System.out.println("影响的行数"+result2);

        List<Long> longs = Arrays.asList(1L, 2L);
        int result3 = userMapper.deleteBatchIds(longs);
        System.out.println("影响的行数"+result3);
    }

结果 

 4.3 根据ID修改数据

@Test
    public void testUpdate()
    {
        User user = new User();
        user.setId(3L);
        user.setName("李四");
        int result = userMapper.updateById(user);
        System.out.println("受影响的行数:"+result);
    }

结果 

4.4查询信息

@Test
    public void testSelect()
    {
        // 根据ID查询信息
        User user = userMapper.selectById(4L);
        System.out.println("根据ID查询信息:"+user);

        // 根据ID查询信息
        List<Long> ids = Arrays.asList(3L, 4L);
        List<User> users = userMapper.selectBatchIds(ids);
        for (User user1 : users) {
            System.out.println("根据ID批量查询信息:"+ user1);
        }

        // 根据map条件查询用户信息
        Map<String,Object> map = new HashMap<String,Object>();
        map.put("name","李四");
        map.put("age",28);
        List<User> users1 = userMapper.selectByMap(map);
        for (User user1 : users1) {
            System.out.println("根据map条件查询用户信息:"+user1);
        }
    }

结果

五、通用service

通用 Service CRUD 封装IService接口,进一步封装 CRUD 采用 get 查询单行 remove 删
除 list 查询集合 page 分页 前缀命名方式区分 Mapper 层避免混淆


MyBatis-Plus中有一个接口 IService和其实现类 ServiceImpl,封装了常见的业务层逻辑,详情查看源码IService和ServiceImpl

新建 UserService接口 集成 IService

package com.zym.mybatisplus.service;

import com.baomidou.mybatisplus.extension.service.IService;
import com.zym.mybatisplus.domain.User;

/**
* UserService继承IService模板提供的基础功能
*/
public interface UserService extends IService<User>
{
}

新建 UserServiceImpl

 

package com.zym.mybatisplus.service.impl;

import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.zym.mybatisplus.domain.User;
import com.zym.mybatisplus.mapper.UserMapper;
import com.zym.mybatisplus.service.UserService;
import org.springframework.stereotype.Service;

/**
 * ServiceImpl实现了IService,提供了IService中基础功能的实现
 * 若ServiceImpl无法满足业务需求,则可以使用自定的UserService定义方法,并在实现类中实现
 */
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService
{
}

测试

import com.zym.mybatisplus.service.UserService;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;

@SpringBootTest
public class Test01 {

    @Autowired
    private UserService userService;

    @Test
    public void getCount(){
        long count = userService.count();
        System.out.println("总记录数:"+count);
    }
}

结果

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值