springboot整合mybatis分页(使用pagehelper 分页插件)-- 学习若依系统

学习文档(参考若依系统)

若依的文档:http://doc.ruoyi.vip/ruoyi-vue/document/htsc.html#%E5%88%86%E9%A1%B5%E5%AE%9E%E7%8E%B0

就不从零搭建springboot项目了,直接在自己的项目基础上引入。

1、引入的依赖

<!-- pagehelper 分页插件 -->
<dependency>
    <groupId>com.github.pagehelper</groupId>
    <artifactId>pagehelper-spring-boot-starter</artifactId>
    <version>1.4.5</version>
</dependency>

2、PageHelper分页插件的配置

# PageHelper分页插件
pagehelper:
  helperDialect: mysql
  supportMethodsArguments: true
  params: count=countSql

3、基础类

3.1、引入基类,减少重复的字段

@Data
public class BaseEntity implements Serializable
{
    
    
    private static final long serialVersionUID = 1L;

    /** 搜索值 */
    @JsonIgnore
    private String searchValue;

    /** 创建者 */
    private String createBy;

    /** 创建时间 */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    private Date createTime;

    /** 更新者 */
    private String updateBy;

    /** 更新时间 */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    private Date updateTime;

    /** 备注 */
    private String remark;

    /** 请求参数 */
    @JsonInclude(JsonInclude.Include.NON_EMPTY)
    private Map<String, Object> params;

    public Map<String, Object> getParams()
    {
    
    
        if (params == null)
        {
    
    
            params = new HashMap<>();
        }
        return params;
    }

    public void setParams(Map<String, Object> params)
    {
    
    
        this.params = params;
    }
}

3.2、自己的实体类继续这个基类

@Data
public class SysUser extends BaseEntity {
    
    
	//其他字段...
}

4、controller基础类

4.1、公共的controller

public class BaseController
{
    
    
    protected final Logger logger = LoggerFactory.getLogger(this.getClass());

    /**
     * 将前台传递过来的日期格式的字符串,自动转化为Date类型
     */
    @InitBinder
    public void initBinder(WebDataBinder binder)
    {
    
    
        // Date 类型转换
        binder.registerCustomEditor(Date.class, new PropertyEditorSupport()
        {
    
    
            @Override
            public void setAsText(String text)
            {
    
    
                setValue(DateUtils.parseDate(text));
            }
        });
    }

    /**
     * 设置请求分页数据
     */
    protected void startPage()
    {
    
    
        PageUtils.startPage();
    }

    /**
     * 设置请求排序数据
     */
    protected void startOrderBy()
    {
    
    
        PageDomain pageDomain = TableSupport.buildPageRequest();
        if (StringUtils.isNotEmpty(pageDomain.getOrderBy()))
        {
    
    
            String orderBy = SqlUtil.escapeOrderBySql(pageDomain.getOrderBy());
            PageHelper.orderBy(orderBy);
        }
    }

    /**
     * 清理分页的线程变量
     */
    protected void clearPage()
    {
    
    
        PageUtils.clearPage();
    }

    /**
     * 响应请求分页数据
     */
    @SuppressWarnings({
    
     "rawtypes", "unchecked" })
    protected TableDataInfo getDataTable(List<?> list)
    {
    
    
        TableDataInfo rspData = new TableDataInfo();
        rspData.setCode(HttpStatus.SUCCESS);
        rspData.setMsg("查询成功");
        rspData.setRows(list);
        rspData.setTotal(new PageInfo(list).getTotal());
        return rspData;
    }

    /**
     * 返回成功
     */
    public AjaxResult success()
    {
    
    
        return AjaxResult.success();
    }

    /**
     * 返回失败消息
     */
    public AjaxResult error()
    {
    
    
        return AjaxResult.error();
    }

    /**
     * 返回成功消息
     */
    public AjaxResult success(String message)
    {
    
    
        return AjaxResult.success(message);
    }
    
    /**
     * 返回成功消息
     */
    public AjaxResult success(Object data)
    {
    
    
        return AjaxResult.success(data);
    }

    /**
     * 返回失败消息
     */
    public AjaxResult error(String message)
    {
    
    
        return AjaxResult.error(message);
    }

    /**
     * 返回警告消息
     */
    public AjaxResult warn(String message)
    {
    
    
        return AjaxResult.warn(message);
    }

    /**
     * 响应返回结果
     * 
     * @param rows 影响行数
     * @return 操作结果
     */
    protected AjaxResult toAjax(int rows)
    {
    
    
        return rows > 0 ? AjaxResult.success() : AjaxResult.error();
    }

    /**
     * 响应返回结果
     * 
     * @param result 结果
     * @return 操作结果
     */
    protected AjaxResult toAjax(boolean result)
    {
    
    
        return result ? success() : error();
    }

    /**
     * 页面跳转
     */
    public String redirect(String url)
    {
    
    
        return StringUtils.format("redirect:{}", url);
    }

}

4.2、自己的controller继承公共的controller

@RestController
@RequestMapping("sysUser")
public class SysUserController extends BaseController{
    
    
    /**
     * 服务对象
     */
    @Resource
    private SysUserService sysUserService;

    /**
     * 查看用户列表
     * @param sysUser
     * @return
     */
    @GetMapping("/list")
    public TableDataInfo queryAllByLimit(SysUser sysUser){
    
    
        startPage();
        List<SysUser> list = sysUserService.selectUserList(sysUser);
        return getDataTable(list);
    }

}

5、返回分页数据的处理类

public class TableDataInfo implements Serializable
{
    
    
    private static final long serialVersionUID = 1L;

    /** 总记录数 */
    private long total;

    /** 列表数据 */
    private List<?> rows;

    /** 消息状态码 */
    private int code;

    /** 消息内容 */
    private String msg;

    /**
     * 表格数据对象
     */
    public TableDataInfo()
    {
    
    
    }

    /**
     * 分页
     * 
     * @param list 列表数据
     * @param total 总记录数
     */
    public TableDataInfo(List<?> list, int total)
    {
    
    
        this.rows = list;
        this.total = total;
    }

    public long getTotal()
    {
    
    
        return total;
    }

    public void setTotal(long total)
    {
    
    
        this.total = total;
    }

    public List<?> getRows()
    {
    
    
        return rows;
    }

    public void setRows(List<?> rows)
    {
    
    
        this.rows = rows;
    }

    public int getCode()
    {
    
    
        return code;
    }

    public void setCode(int code)
    {
    
    
        this.code = code;
    }

    public String getMsg()
    {
    
    
        return msg;
    }

    public void setMsg(String msg)
    {
    
    
        this.msg = msg;
    }
}

6、测试分页

在这里插入图片描述
在这里插入图片描述

7、个人感受

在使用若依的分页时,引入了很多的工具类,是不是太臃肿,可以试试myabtis-plus的分页插件。
这是在引入分页时,防止报错引入关联的类。
在这里插入图片描述

个人的学习理解,在此记录,更多的使用去官网了解吧。

结束!!
hy:24


						只有在困难中,我们才能发现自己的真正价值和潜力。

猜你喜欢

转载自blog.csdn.net/weixin_49107940/article/details/132050752