Spring Boot整合Mybatis-Plus和PageHelper分页插件

Spring Boot整合Mybatis-Plus和PageHelper分页插件

1 导入依赖

		<!--Lombok提供了一组有用的注释,用来消除Java类中的大量样板代码-->
	 <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <!--mybatis-plus-->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.0.5</version>
        </dependency>
        <!--MyBatis分页插件-->
        <dependency>
            <groupId>com.github.pagehelper</groupId>
            <artifactId>pagehelper</artifactId>
            <version>5.2.0</version>
        </dependency>

2 application.yml文件配置数据连接池和PageHelper

server:
  port: 8002

spring:
  datasource:
    url: jdbc:mysql://localhost:3306/j12emp?useUnicode=true&characterEncoding=utf8&serverTimezone=GMT%2B8&useSSL=false
    username: root
    password: 123456
    driver-class-name: com.mysql.cj.jdbc.Driver

############# 分页插件PageHelper配置 #############
pagehelper:
  helper-dialect: mysql
  reasonable: true
  support-methods-arguments: true
  pageSizeZero: true
  params=count: countSql

3 实体类Emp

package com.yy.pojo;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.util.Date;

@Data
@AllArgsConstructor
@NoArgsConstructor
@TableName("emp")
public class Emp {
    @TableId(value = "eid", type = IdType.AUTO)
    private Integer eid;
    private String ename;
    private Double salary;
    private Date bir;
}

4 消息类Message(整理返回前端数据)

package com.yy.pojo;

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.util.HashMap;
import java.util.Map;

@Data
@AllArgsConstructor
@NoArgsConstructor
public class Message {
    // 返回的 状态码   自己定义  如 101  成功  102 失败
    private int code;
    // 返回的提示信息
    private String ms;
    // 返回的携带数据
    private Map<String,Object> map=new HashMap<>();
    // 再加两个常用的 成功失败
    public static Message success(){
        Message mes=new Message();
        mes.setCode(101);
        mes.setMs("处理成功");
        return  mes;
    }
    public static Message fail(){
        Message mes=new Message();
        mes.setCode(102);
        mes.setMs("处理失败");
        return  mes;
    }
    // 增加一个链式操作的添加
    public Message add(String key,Object val){
        this.getMap().put(key,val);
        return this;
    }
}

5 Dao层继承extends BaseMapper接口,mybatis-plus整合实现了基本的CRUD

package com.yy.dao;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.yy.pojo.Emp;

/**
 * @Author: Yang
 * @Date: 2022/3/3 19:10
 * @Description:
 */
public interface EmpDao extends BaseMapper<Emp> {
}

6 启动类添加@MapperScan(“mapper类包的路径”),使用@MapperScan注解扫描dao层,dao接口不用再添加@Mapper注解

package com.yy;

import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

/**
 * @Author: Yang
 * @Date 2022/3/3 19:01
 * @Description:
 */
@SpringBootApplication
@MapperScan("com.yy.dao")
public class EmpApplication {
    public static void main(String[] args) {
        SpringApplication.run(EmpApplication.class, args);
    }
}

7 Service层代码

package com.yy.service;

import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import com.yy.dao.EmpDao;
import com.yy.pojo.Emp;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;

/**
 * @Author: Yang
 * @Date 2022/3/3 19:10
 * @Description:
 */
@Service
public class EmpService {
    @Autowired
    EmpDao empDao;

    /**
     * @Description: 员工展示,带分页,搜索
     * @Param: [pageIndex: 页数  , pageSize: 页码 , search: 搜索信息 ]
     * @Return: Message
     */
    public PageInfo<Emp> list(Integer pageIndex, Integer pageSize, String search){
        // 启动分页
        PageHelper.startPage(pageIndex, pageSize);
        QueryWrapper<Emp> queryWrapper = new QueryWrapper<>();
        queryWrapper.like(search != null, "ename", search);
        List<Emp> list = empDao.selectList(queryWrapper);
        PageInfo<Emp> pageInfo = new PageInfo<>(list);
        System.out.println(pageInfo);
        return pageInfo;
    }

    /**
     * @Description: 员工添加
     * @Param: [emp: 员工对象 ]
     * @Return: 数据库影响行数
     */
    public Integer add(Emp emp) {
        return empDao.insert(emp);
    }

     /**
     * @Description: 员工根据Id删除
     * @Param: [emp: 员工对象 ]
     * @Return: 数据库影响行数
     */
    public Integer del(Integer eId) {
        return empDao.deleteById(eId);
    }

      /**
     * @Description: 员工更新
     * @Param: [emp: 员工对象 ]
     * @Return: 数据库影响行数
     */
    public Integer update(Emp emp) {
        return empDao.updateById(emp);
    }
}

8 Controller层代码

package com.yy.controller;

import com.github.pagehelper.PageInfo;
import com.yy.pojo.Emp;
import com.yy.pojo.Message;
import com.yy.service.EmpService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.*;

import java.util.List;
/**
 * @Author: Yang
 * @Date 2022/3/3 19:10
 * @Description:
 */
@Controller
@ResponseBody
@RequestMapping("/emp")
public class EmpController {
    @Autowired
    EmpService empService;

    /**
     * @Description: 员工展示,带分页,搜索
     * @Param: [pageIndex: 页数  , pageSize: 页码 , search: 搜索信息 ]
     * @Return: Message
     */
    @GetMapping("/")
    public Message list(@RequestParam(defaultValue = "1") Integer pageIndex,
                        @RequestParam(defaultValue = "3") Integer pageSize,
                        String search) {
        PageInfo<Emp> empPageInfo = empService.list(pageIndex, pageSize, search);
        return Message.success().add("empPageInfo", empPageInfo);
    }

    /**
     * @Description: 员工添加
     * @Param: [emp: 员工对象 ]
     * @Return: Message
     */
    @PostMapping("/")

    public Message add(@RequestBody Emp emp) {
        Integer integer = empService.add(emp);
        if (integer>0){
            return Message.success().add("emp", emp);
        }else {
            return Message.fail();
        }
    }

    /**
     * @Description: 员工更新
     * @Param: [emp: 员工对象 ]
     * @Return: 数据库影响行数
     */
    @PutMapping("/")
    public Message update(@RequestBody Emp emp) {
        if (empService.update(emp) > 0) {
            return Message.success().add("emp", emp);
        }
        return Message.fail().add("emp", emp);
    }

    /**
     * @Description: 员工根据Id删除
     * @Param: [emp: 员工对象 ]
     * @Return: 数据库影响行数
     */
    @DeleteMapping("/")
    public Message del(Integer eId) {
        if (empService.del(eId) > 0) {
            return Message.success();
        }
        return Message.fail();
    }
}

9 Postman测试

在这里插入图片描述

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
spring boot整合mybatis-pluspagehelper分页插件是一种常见的开发方式,可以实现数据库的分页查询功能。下面是一个简单示例项目的源码,以供参考: 首先,需要在pom.xml文件中添加相关依赖: ```xml <dependencies> <!-- Spring Boot --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter</artifactId> </dependency> <!-- MyBatis Plus --> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.4.0</version> </dependency> <!-- PageHelper --> <dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper-spring-boot-starter</artifactId> <version>1.3.0</version> </dependency> <!-- MySQL Connector --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.27</version> </dependency> </dependencies> ``` 在application.properties(或application.yml)文件中配置数据库连接信息: ```yaml spring.datasource.url=jdbc:mysql://localhost:3306/mydatabase spring.datasource.username=root spring.datasource.password=123456 spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver mybatis-plus.configuration.map-underscore-to-camel-case=true ``` 创建一个简单的实体类User: ```java public class User { private Long id; private String username; private String password; // 省略getter和setter方法 } ``` 创建一个Mapper接口UserMapper: ```java @Mapper public interface UserMapper extends BaseMapper<User> { // 省略其他方法 List<User> getUsersByPage(Page<User> page, @Param("username") String username); } ``` 创建一个Service接口UserService以及其实现类UserServiceImpl: ```java @Service public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService { @Autowired private UserMapper userMapper; @Override public IPage<User> getUsersByPage(Page<User> page, String username) { return userMapper.getUsersByPage(page, username); } } ``` 在Controller中注入UserService,并进行分页查询操作: ```java @RestController public class UserController { @Autowired private UserService userService; @GetMapping("/users") public IPage<User> getUsers(@RequestParam(value = "page", defaultValue = "1") Integer pageNum, @RequestParam(value = "size", defaultValue = "10") Integer pageSize, @RequestParam(value = "username", required = false) String username) { Page<User> page = new Page<>(pageNum, pageSize); return userService.getUsersByPage(page, username); } } ``` 至此,就完成了spring boot整合mybatis-pluspagehelper分页插件的配置和使用。 请注意,这是一个简单示例项目,实际使用中可能需要根据需求进行适当调整和修改。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值