【环球报资讯】MyBatis-Plus 实现动态字段排序
时间:2023-06-23 19:06:43来源:博客园


(资料图片)

场景

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

业务需求

思路

  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 实现动态字段排序

    场景 虽然前端能根据返回的数组进行对字段的排序,但也仅局限于实现

  • 汽开区党政主要领导会见神州数码高级副总裁孙洋

    6月20日,汽开区党工委书记朱光明,党工委副书记、管委会主任李国辉会

  • 剑与远征命运困境3怎么过(剑与远征命运困境怎么通关) 天天快资讯

    剑与远征命运困境3怎么过?剑与远征命运困境3已经开启,很多玩家不知道

  • 【宋代】周行己的二十首诗作,值得品读

    周行己(1067-1125),字恭叔,世称浮沚先生。祖籍瑞安县芳山乡文周

  • 端午出行 这很“粽”要!

    2023年端午假期为2023年6月22日至6月24日。节日期间,江西高速公路小型

  • 全球快资讯:ChatGPT:黄子佼自杀前指认大小S吸毒等明星黑料,可信度有多少?

    你认为黄子佼自杀之前指认大小S吸毒和范晓萱,阿雅等一众明星的黑料,

  • 91年属羊女财运方位,91属羊财运方向(91年属羊女运势如何)

    一、属羊人的财位在哪里属羊人的财位是北方和西北方。二、属羊人的更佳

  • 自贡市自流井区:“邻”距离打造宜居家园

    “现在房前屋后环境也变好了,遇到问题打个电话就能解决,比以前方便多

  • 【网络中国节·端午】烟村江畔荷灯亮 祝福安康情绵长-新资讯

    6月21日下午,由歙县县委宣传部、歙县文化旅游体育局指导,歙县王村镇

  • 安徽宿松:非遗产业让传统手艺为村民致富插上翅膀-环球观热点

    近年来,安徽省宿松县贯彻“保护为主、抢救第一、合理利用、传承发展”

  • 端午节去哪玩?这个地方一定要去!

    点燃夏日激情放肆去“嗨”!6月22日15:00由南通创新区主办的打造“南通

  • 博迅生物上会通过 采购数据或不真实-环球热讯

    6月16日,北交所上市委员会召开了2023年第30次审议会议,审议会议结果

  • 环球播报:极狐法务部开通微博,首条内容“怒怼”车评人,发生了什么?

    炒股就看金麒麟分析师研报,权威,专业,及时,全面,助您挖掘潜力主题

  • 每日速讯:如何清理电脑桌面?怎么快速清理电脑桌面?

    如何清理电脑桌面?第一步、清理所有桌面上的图标,注意是快捷方式的

  • 环球快消息!2023最新的十个开箱网有哪些? c5game开箱具体详细地址分享

    CSGO国服服务器是多少tickCSGO的服务器使用的是国家一级骨干节点,

  • 当前关注:某个旅人的日记_关于某个旅人的日记概略

    1、某个旅人的日记或る旅人の日记(又名:奇幻的异世界托鲁塔利亚的游

  • 旅游
    • 坦克500 Hi4-T将于6月底上市,坦克400 Hi4-T华南首秀

    • 【环球速看料】签位出炉!张本智和运气好,伊藤美诚、早田希娜、张本美和扎堆

    • 自己剪刘海(自己剪刘海最简单方法)_世界观热点

    • 创速递丨南京燃点生物完成数千万元B轮融资