前言
MybatisPlus 分页插件还是很强大的,但是部分功能需要根据项目需要自行调整;比如在排序时,由于数据库表字段与实体类字段不一致(可能是驼峰规则),这个时候如果前台传递的排序参数是实体类字段,则会报异常提示字段不存在,这个时候我们有2种解决办法,一是修改前台传递的参数与数据库字段保持一致,二是后台根据实体类映射自动转换成表字段。
方法
两种方法都是可行的,但是站在长远角度上考虑建议第二种方式,分析如下:
1、如果前台修改字段,会增加前端代码的复杂度,因为技术员除了需要获取实体类字段还需要知道对应的表字段,如果是修改后端,前端只需要将排序字段与获取数据的字段保持一致即可
2、如果是修改后端,我们可以包装一个工具类 专门用于分页,在工具类里重写Page类,利用类的反射将排序字段自动转换为对应的数据库表字段,这样如果其他模块需要,只需要引入该工具类即可
直接上代码
工具类
PageUtil.java
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117
| 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; } }
|
service 使用
1 2 3 4 5 6 7 8
| public IPage<Project> getPageList( PageUtil<Project> page, ) throws Exception { page.convertFields(Project.class); return projectService.getPageList(page); }
|