首页 > 食品

MyBatis-Plus 实现动态字段排序 焦点关注

来源:博客园 时间:2023-06-22 20:16:27


(资料图片)

场景

虽然前端能根据返回的数组进行对字段的排序,但也仅局限于实现当前页的排序,无法满足全部数据的排序,所以需要走接口的查询进行排序,获取最全的排序数据。

业务需求

思路

  1. 前端需传递排序的字段,该字段是正序还是倒叙。可能存在多个,所以字段为字符串数组,可以通过逗号分开。
  2. 后端拿到参数后,如果字段名是驼峰命名,需要转为小写字母+下划线命名。
  3. 将处理后的字段进行排序sql上的拼接处理后,拼接到 order by 语句后面,得到order by语句。
  4. 根据MyBatis-Plus的 last方法,将处理的order by语句进行拼接到查询sql语句后面。

实现

  1. 前端传递的参数格式为:
{  "sort": "userName,updateTime",  "order": "asc,desc"}
  1. 后端接收排序对象 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;        }    }}
  1. 处理字段驼峰式的工具类:
/** 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();    }}
  1. 请求查询的入参对象继承 Sorter排序对象:
入参对象
  1. Mapper层直接调用last在sql尾拼接语句方法,将SortergetOrderByStatement(Sorter sorter)方法传入:
语句拼接

结果

测试排序

相关稿件

MyBatis-Plus 实现动态字段排序 焦点关注

告别五花八门的车身,贵阳出租车将统一换装亮相!“新衣”长这样

科学家利用 AI 识别热门歌曲,准确率高达 97%|世界今亮点

今日最新!【津云镜头】百舸争流庆端午 千帆竞渡赛龙舟

新年快乐钢琴谱简单版(新年快乐365hddvd)|天天报资讯

环球快讯:海口杨氏家族,一笔收购挣到60亿

2023年度中国火锅连锁品牌TOP30

跟罗永浩“交个朋友”,京东直播将改变什么?

龙舟竞渡,公安守护,这道最美“警”色不容错过! 天天热议

刘诗诗《白日提灯》筹拍,男主之争愈演愈烈,潘粤明或也有望入局

日本将要求苹果开放第三方应用商店!

神化引

天天热推荐:歙县1宗商住、1宗商服用地均以底价成交

讯息:【有趣】第79期:十几块钱的散热器凭什么可以镇压i7处理器?

湖南慈利一女子派出所等候询问时死亡 家属称希望看到派出所内全部监控_世界热讯

2023纵览高招会丨河北地质大学:在河北招生计划为2180人 计算机科学与技术专业(校企深度合作办学项目)首次招生 全球热推荐

天气预报 讯息

高标准建设红色旅游驿站 新平台整合绿色文旅资源——敦化市雁鸣湖镇推进乡村旅游量质齐飞

夏至到 节令美食都有啥?-全球新要闻

焦点速读:公司私用他人信息获利 原告要求赔偿获得支持

“共享储能”,为什么被称为储能最好的商业模式?

魔兽世界灵翼幼龙声望怎么开启(wowtbc怀旧服灵翼幼龙声望开启方法)

OK镜集采结果出炉,采了个寂寞?

当前要闻:茶叶制作一般有哪些步骤

拉夏贝尔正式破产清算 网友:曾是我的青春回忆……

618的新战役:谈布局、拼低价、更落地|当前热闻

当前聚焦:莲湖区:500名教师兼任急救员 实现校园急救员全覆盖

天天热讯:孝义:说好5月底公示公交线路、小程序,至今还没?

全球热讯:穿成女扮男装的摄政王_女主女扮男装当摄政王

5年期LPR为何只降10个基点?_环球观热点