【环球快播报】MyBatis-Plus 实现动态字段排序
时间:2023-06-22 08:23:37来源:博客园


【资料图】

场景

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

业务需求

思路

  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)方法传入:
语句拼接

结果

测试排序

标签:

生活指南
  • 焦点日报:璞泰来:拟2亿元-3亿元回购公司股份,回购价不超54.31元/股

    璞泰来6月21日公告,公司拟以自有资金或自筹资金以集中竞价交易方式回

  • 肯德基全家桶多少钱一桶2023年?正版adobe全家桶多少钱? 焦点快看

    肯德基全家桶多少钱一桶2023年? 黄金脆皮鸡新春桶 108元 桶(香辣鸡

  • 有志难伸_对于有志难伸简单介绍-每日精选

    1、汉语成语,拼音是yǒuzhìnánshēn,意思是有远大抱负而难以施展。

  • 环球快播:鞍山师范学院录取查询系统2021_鞍山师范学院录取查询

    1、现在应该是已经发了,就在邮局的路上。2、你登陆学校招生办的网站,

  • 北京的演唱会一般在哪里举行?2023年北京的演唱会有哪些? 今日精选

    北京的演唱会一般在哪里举行?大型演唱会常用举办场地:凯迪拉克中心

  • 常见的电子邮箱有哪些?yy直播间怎么赚钱? 最新资讯

    常见的电子邮箱有哪些在网络中,电子邮箱可以自动接收网络任何电子

  • 价值投资的核心内容是什么?价值投资和成长投资的不同点

    最近小编看到很多人在搜索价值投资的相关内容,小编呢对此也是非常

  • 欧洲冠军联赛奖金是多少欧元?中国足球在欧洲比赛是什么水平?

    欧洲冠军联赛奖金是多少欧元?欧洲冠军联赛奖金因赛季不同而有所变化

  • 天天看点:新三板到主板要多久?新三板转主板需要哪些条件?

    企业需要选择适合自己的上市板块。对于一些小型企业来说,新三板是

  • 全球微动态丨【甘快看】短视频制作、直播带货免费培训来袭,你务必要来!

    您是否想搭上直播带货的快车? 您是否摄制的短视频播放量不高? 您是

  • 欠网商贷了5万三年没还支付宝不显示怎么办?支付宝收款后会不会冻结?

    在现代社会,贷款已经成为了人们生活中不可或缺的一部分。但是,如果贷

  • 世界热文:沙滩地适合种什么 沙滩地适合种哪些植物

    1、种植杨树。杨树的生长速度较快,根系发达,在土质疏松的地方生长快

  • 天天快看:快讯!俄媒:普京称,乌军试图发动反攻,但没有反攻机会

    【环球网快讯】据俄新社报道,俄罗斯总统普京16日出席圣彼得堡国际经济

  • 每日快报!挖机开进门面房,打通多间墙体还下挖地面!被叫停后竟再次开工!

    日前,有连云港观众反映说,小区一楼多间门面房被产权人出租后,承租人

  • 今日纸白银价格行情(2023年6月16日)

    今日纸白银价格行情(2023年6月16日)

  • 王姬别动我抽屉_别动我抽屉-每日热讯

    1、是电影东北恋歌。2、包贝尔原名艾志超,出生于黑龙江哈尔滨市,毕业

  • 民生
    • 世界球精选!76场演出、12个夏令营、3个音乐马拉松等你来

    • 中国中冶:拟向特定对象发行优先股募资不超150亿元

    • 哈尔滨毕业生户口迁移

    • 火电核电重启电不荒,加码绿能奔向碳中和_天天快讯