首页 > 其他分享 >MyBatis-Plus 实现动态字段排序

MyBatis-Plus 实现动态字段排序

时间:2023-06-21 16:00:40浏览次数:31  
标签:return String Plus statement MyBatis 排序 order append

场景

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

业务需求

思路

  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. 基础排序对象,包含排序字段和排序方式
 */
@Data
public 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)方法传入:

语句拼接

结果

测试排序

标签:return,String,Plus,statement,MyBatis,排序,order,append
From: https://www.cnblogs.com/lin02/p/17496411.html

相关文章

  • Mybatis Plus 批量插入方法效率低问题优化方案 BatchExcutor
    1、问题描述项目用的是MybatisPlus框架操作数据库,在使用batchSave批量插入方法的时候发现效率极低,插入2w数据花了6分钟,太恐怖了。看了源码发现,项目的批量插入方法调用的是MybatisPlus的BatchExcutor,用这个本意是将多次更新sql语句集合为一条更新语句,复用同一个sql连接更新数据。......
  • 希尔排序的实现
    #include<stdio.h>#include<stdlib.h>typedefintKeyType;typedefstruct{KeyType*elem;/*elem[0]一般作哨兵或缓冲区*/intLength;}SqList;voidCreatSqList(SqList*L);/*待排序列建立,由裁判实现,细节不表*/voi......
  • 插入排序及C语言实现
    一、插入排序原理插入排序是一种简单的排序算法,其基本思想是将未排序序列中的每个元素依次插入到已排序的序列中合适的位置。具体来说,假设待排序的序列为a1,a2,⋯,an,则从a2开始遍历整个序列,将ai插入到前面的已排序序列a1,⋯,ai−1中,直到所有的元素都被插入到已排序的序列中......
  • 自定义机会排序
    publicclassSortTest{privatestaticfinalList<String>technologyOrder=newArrayList<>();privatestaticfinalList<Student>students=newArrayList<>();static{technologyOrder.add("DDD");......
  • MyBatis入门指南
    MyBatis起源于iBatis,iBatis是ClintonBegin在2002年发起的开源项目,于2010年6月16日从Apache的网站退役,并被GoogleCode托管,改名为MyBatis。MyBatis是一个支持普通SQL查询、存储过程和高级映射的优秀的持久层框架,它消除了几乎所有的JDBC代码、对参数的手工设置以及对结果集繁琐的处......
  • Vue3 element-Plus el-tree 权限树 传值给后端及回显问题
    内容:权限在新增人员时候选择传给后端并且编辑回显坑:1.传给后端的权限数组需要传父级id例如:一级目录下有二级目录和2-2目录,选了2-2目录,需要把一级目录的id也给后端2.回显的时候后端会把权限数组id都给你(包括一级目录),如果直接回显的话会默认一级下所有目录都选中 代......
  • Docker配置SpringBoot+ShardingJDBC+MybatisPlus项目实现分库分表与读写分离
    Docker配置SpringBoot+ShardingJDBC+MybatisPlus项目实现分库分表与读写分离 分类于 实战例子本文ShardingJDBC相关知识主要参考自ShardingJDBC官方文档,更多的用法建议到官网文档查看。前言传统的业务系统都是将数据集中存储至单一数据节点的解决方案,如今随着互联网数据......
  • 数据结构和算法系列课程(01)--- 排序二叉树和红黑树
    把排序二叉树放在这个系列课程的第一个部分似乎有些唐突,但是考虑到它在面试中出现的可能性,把它放在这样的一个位置也就不足为奇了。关于树和二叉树的基础知识,可以到下面的链接中下载我的课件进行了解。下面给出一个排序二叉树的Java实现:packagcom.loonstudio;/***排序二叉树......
  • mybatis在mapper.xml中怎么处理大于、小于、不等于号
    第一种方法:使用转义字符大于号>>大于等于号 >= >=小于号 < < 小于等于号 <= <=与 & &amp;双引号 " "单引号 ' &apos;例子: <iftest="beginTimeStr!=null">  andfile.created_at>='${beginTimeStr}'</if>......
  • MySQL单表查询练习(条件_模糊_分组_聚合_排序)
    练习所用数据表•部门表CREATETABLEDEPT(DEPTNOINTPRIMARYKEY,–部门编号DNAMEVARCHAR(14),–部门名称LOCVARCHAR(13)–部门地址);INSERTINTODEPTVALUES(10,‘ACCOUNTING’,‘NEWYORK’);INSERTINTODEPTVALUES(20,‘RESEARCH’,‘DALLAS’);......