MybatisPlus重写Page排序参数之PageUtil的诞生

        MybatisPlus 分页插件还是很强大的,但是部分功能需要根据项目需要自行调整;比如在排序时,由于数据库表字段与实体类字段不一致(可能是驼峰规则),这个时候如果前台传递的排序参数是实体类字段,则会报异常提示字段不存在,这个时候我们有2种解决办法,一是修改前台传递的参数与数据库字段保持一致,二是后台根据实体类映射自动转换成表字段

        两种方法都是可行的,但是站在长远角度上考虑建议第二种方式,分析如下:
1、如果前台修改字段,会增加前端代码的复杂度,因为技术员除了需要获取实体类字段还需要知道对应的表字段,如果是修改后端,前端只需要将排序字段与获取数据的字段保持一致即可
2、如果是修改后端,我们可以包装一个工具类 专门用于分页,在工具类里重写Page类,利用类的反射将排序字段自动转换为对应的数据库表字段,这样如果其他模块需要,只需要引入该工具类即可

直接上代码

PageUtil.java

import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.List;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.core.toolkit.StringUtils;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.fasterxml.jackson.annotation.JsonInclude;
@JsonInclude(JsonInclude.Include.NON_NULL)
public class PageUtil<T> extends Page<T> {
	private static final long serialVersionUID = 1L;
	/**
     * 	第几页
     */
	private Integer currentPage;
	/**
     * 	每页条数
     */
	private Integer pageSize;
	 /**
     * 	设置需要进行正序排序的字段
     */
	private String ascs;
	/**
     * 	设置需要进行倒序排序的字段
     */
	private String descs;
	
	 
	public Integer getCurrentPage() {
		return currentPage;
	}
	public void setCurrentPage(Integer currentPage) {
		super.setCurrent(currentPage);
		this.currentPage = currentPage;
	}
	public Integer getPageSize() {
		return pageSize;
	}
	public void setPageSize(Integer pageSize) {
		super.setSize(pageSize);
		this.pageSize = pageSize;
	}
	public String getAscs() {
		return ascs;
	}
	public void setAscs(String ascs) {
		this.ascs = ascs;
	}
	
	public String getDescs() {
		return descs;
	}
	public void setDescs(String descs) {
		this.descs = descs;
	}
	public static long getSerialversionuid() {
		return serialVersionUID;
	}
	
	@SuppressWarnings("deprecation")
	public void convertFields(Class<T> entityClass) {
		if(!StringUtils.isBlank(getAscs())) {
			super.setAscs(convertFields(ascs.split(","),entityClass));
		}
		if(!StringUtils.isBlank(getDescs())) {
			super.setDescs(convertFields(descs.split(","),entityClass));
		}
	}
	
	/**
     * 	因为排序字段可能与数据库字段不一致 所以需要转换成一致
     */
	public List<String> convertFields(String [] fields,Class<T> entityClass) {
		List<String> list=new ArrayList<String>();
		if(fields!=null && fields.length>0) {
			//通过反射 匹配正确字段
			for (String field : fields) {
				try {
					String value=null;
					Field f=null;
					try {
						f = entityClass.getDeclaredField(field);
					}catch(Exception e) {
						try {
							//父类寻找
							Class<?> s=entityClass.getSuperclass();
							f = s.getDeclaredField(field);
						} catch (Exception e2) {
							list.add(field);
							continue;
						}
					}
					TableField tableField=f.getAnnotation(TableField.class);
					if(tableField!=null) {
						value=tableField.value();
					}else {
						TableId tableId=f.getAnnotation(TableId.class);
						if(tableId!=null) {
							value=tableId.value();
						}
					}
					if(value==null || value.equals("")) {
						value=field;
					}
					list.add(value);
				} catch (SecurityException e) {
					e.printStackTrace();
				}  
				
			}
			return list;
		}
		return null;
	}
	
}

controller

public IPage<Project> getPageList(
			PageUtil<Project> page,
			) throws Exception
	{
        //手动触发 转换
		page.convertFields(Project.class);
		return projectService.getPageList(page);
	}

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值