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

2023-05-16

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

在这里插入图片描述

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Spring Boot整合Mybatis-Plus和PageHelper分页插件 的相关文章

随机推荐