MyBatis-Plus 实现动态字段排序
2023-06-21 20:29:30 来源:博客园
(资料图片)
场景
虽然前端能根据返回的数组进行对字段的排序,但也仅局限于实现当前页的排序,无法满足全部数据的排序,所以需要走接口的查询进行排序,获取最全的排序数据。
思路
- 前端需传递排序的字段,该字段是正序还是倒叙。可能存在多个,所以字段为字符串数组,可以通过逗号分开。
- 后端拿到参数后,如果字段名是驼峰命名,需要转为小写字母+下划线命名。
- 将处理后的字段进行排序sql上的拼接处理后,拼接到 order by 语句后面,得到order by语句。
- 根据MyBatis-Plus的
last
方法,将处理的order by语句进行拼接到查询sql语句后面。
实现
- 前端传递的参数格式为:
{ "sort": "userName,updateTime", "order": "asc,desc"}
- 后端接收排序对象
Sorter
,那个请求查询用到自定义排序就继承该类:
import io.swagger.annotations.ApiModelProperty;import lombok.Data;/** 1. 基础排序对象,包含排序字段和排序方式 */@Datapublic class Sorter{ @ApiModelProperty(value = "排序字段",example = "userName") private String sort; @ApiModelProperty(value = "排序方式",example = "asc/desc") private String order; /** * 根据查询条件拼接得到order by语句 * @param sorter 分页查询条件 * @return String */ public static String getStatement(Sorter sorter) { String sort; String[] sortArray = {}; String[] orderArray = {}; String order = sorter.getOrder(); String sortColumn = sorter.getSort(); StringBuilder statement = new StringBuilder(); // 多字段排序 if (StringUtils.isNotEmpty(sortColumn)) { // 驼峰命名转为下划线 sort = StringUtils.toUnderScoreCase(sortColumn); if (sort.contains(",")) { sortArray = sort.split(","); } } else { return ""; } if (StringUtils.isNotEmpty(order)) { if (order.contains(",")) { orderArray = order.split(","); } } else { return ""; } if (sortArray.length > 0 && orderArray.length > 0) { int length = sortArray.length; for (int i = 0; i < length; i++) { statement.append(sortArray[i]); statement.append(" "); statement.append(orderArray[i]); if (i < length - 1 ) { statement.append(", "); } } } else { // " #{sort} #{order}“ statement.append(sort); statement.append(" "); statement.append(order); } return statement.toString(); } /** * 根据查询条件拼接得到order by语句 * @param sorter 分页查询条件 * @return String */ public static String getOrderByStatement(Sorter sorter) { String statement = getStatement(sorter); if (StringUtils.isNotEmpty(statement)) { return " order by " + statement; } else { return statement; } }}
- 处理字段驼峰式的工具类:
/** 3. 字符串工具类 4. 5. @author lcl */public class StringUtils extends org.apache.commons.lang3.StringUtils{ /** 下划线 */ private static final char SEPARATOR = "_"; /** * * 判断一个字符串是否为非空串 * * @param str String * @return true:非空串 false:空串 */ public static boolean isNotEmpty(String str) { return !isEmpty(str); } /** * 驼峰转下划线命名 */ public static String toUnderScoreCase(String str) { if (str == null) { return null; } StringBuilder sb = new StringBuilder(); // 前置字符是否大写 boolean preCharIsUpperCase = true; // 当前字符是否大写 boolean curreCharIsUpperCase = true; // 下一字符是否大写 boolean nexteCharIsUpperCase = true; for (int i = 0; i < str.length(); i++) { char c = str.charAt(i); if (i > 0) { preCharIsUpperCase = Character.isUpperCase(str.charAt(i - 1)); } else { preCharIsUpperCase = false; } curreCharIsUpperCase = Character.isUpperCase(c); if (i < (str.length() - 1)) { nexteCharIsUpperCase = Character.isUpperCase(str.charAt(i + 1)); } if (preCharIsUpperCase && curreCharIsUpperCase && !nexteCharIsUpperCase) { sb.append(SEPARATOR); } else if ((i != 0 && !preCharIsUpperCase) && curreCharIsUpperCase) { sb.append(SEPARATOR); } sb.append(Character.toLowerCase(c)); } return sb.toString(); }}
- 请求查询的入参对象继承
Sorter
排序对象:
- Mapper层直接调用
last
在sql尾拼接语句方法,将Sorter
的getOrderByStatement(Sorter sorter)
方法传入:
结果
关键词:
相关阅读
-
MyBatis-Plus 实现动态字段排序
场景 虽然前端能根据返回的数组进行对字段的排序,但也仅局限于实现 -
【热闻】微pe工具箱启动不了解决方法
微pe工具箱是一款用于修复和维护计算机系统的工具。然而,有时候您可能 -
沧州明珠拟投资35亿元建设湿法锂电隔膜...
本报记者张晓玉6月21日,沧州明珠公告称,公司拟在沧州高新区投资建设1 -
山西前5个月累计抽采煤层气43.6亿立方米
煤层气(瓦斯)被称为煤矿“井下杀手”,但同时也是高效清洁的能源... -
可川科技:拟设立子公司不涉及800G高速...
证券时报e公司讯,可川科技(603052)6月21日晚间发布股票交易异动公告称 -
太白县幼儿园开展“家社携手 科学衔接...
本报讯(通讯员宫肖云)“五月五,是端午;桃儿红,杏儿黄……”为... -
快讯:新亚电子:公司参股30%公司苏州科...
同花顺金融研究中心6月21日讯,有投资者向新亚电子提问,公司参股的科 -
【短讯】人社部:各地要组建速裁庭,优...
【短讯】人社部:各地要组建速裁庭,优先受理农民工工资争议案。新闻资 -
世界新动态:第一届天津海河文旅消费周...
第一届天津海河文旅消费周暨海河音乐节举办20余特色场景亮相, -
银邦股份(300337.SZ)主要股东新邦科技减...
银邦股份(300337 SZ)公告,公司持股5%以上股东无锡新邦科技有限公司(“ -
全球速递!迎端午,与培智学校的孩子们...
临近端午佳节团圆幸福的氛围愈来愈浓今天一群特殊学生收获了关爱和温暖 -
李鹏在积石山县调研督导有关工作时要求...
法治甘肃网讯(新甘肃·甘肃法制报记者陈孝志)6月15日,临夏州委常... -
安巢老年教育结硕果 合肥赛场论剑传捷报
颁奖现场。韩白霞供图在刚刚落下帷幕的由合肥市老干部教育委员会与合肥 -
开屏观察|又双叒叕上热搜!关于工资这...
开屏观察|又双叒叕上热搜!关于工资这件事,这届年轻人都“躺平”... -
华夏人寿马鞍山中心支公司因未按规定进...
中国网财经6月21日讯(记者李冰)近日,马鞍山银保监分局披露行政处罚信 -
天天观察:四子王旗:解锁一处新的“网...
当下,随着旅游行业的复苏,“民宿热”也不断升温,为满足尘世喧嚣... -
环球快看:失业补助金领取需要提交什么...
怎样领取失业补助金的流程是什么?失业补助金领取需要提交什么材料?接 -
鄂尔多斯市总工会开展“关爱职工·健康...
中工网讯6月20日,内蒙古鄂尔多斯市总工会联合鄂尔多斯市妇幼保健院开 -
每日热文:肇事逃逸?兴安盟交警36小时...
5月23日晚20时许兴安盟G334线附近发生一起交通肇事逃逸案兴安盟科右中 -
【天天聚看点】银川市住房公积金使用政...
银川市住房公积金使用政策有调整!,贷款,银川市,首付款,商品住房,使用