国产精品久久99,51久久成人国产精品麻豆,亚洲欧洲免费三级网站,最近中文字幕mv,重口老太大和小伙乱

首頁(yè)>娛樂(lè) > 正文

MyBatis-Plus 實(shí)現(xiàn)動(dòng)態(tài)字段排序

2023-06-24 06:37:09來(lái)源:博客園


(資料圖片僅供參考)

場(chǎng)景

雖然前端能根據(jù)返回的數(shù)組進(jìn)行對(duì)字段的排序,但也僅局限于實(shí)現(xiàn)當(dāng)前頁(yè)的排序,無(wú)法滿(mǎn)足全部數(shù)據(jù)的排序,所以需要走接口的查詢(xún)進(jìn)行排序,獲取最全的排序數(shù)據(jù)。

業(yè)務(wù)需求

思路

  1. 前端需傳遞排序的字段,該字段是正序還是倒敘??赡艽嬖诙鄠€(gè),所以字段為字符串?dāng)?shù)組,可以通過(guò)逗號(hào)分開(kāi)。
  2. 后端拿到參數(shù)后,如果字段名是駝峰命名,需要轉(zhuǎn)為小寫(xiě)字母+下劃線(xiàn)命名。
  3. 將處理后的字段進(jìn)行排序sql上的拼接處理后,拼接到 order by 語(yǔ)句后面,得到order by語(yǔ)句。
  4. 根據(jù)MyBatis-Plus的 last方法,將處理的order by語(yǔ)句進(jìn)行拼接到查詢(xún)sql語(yǔ)句后面。

實(shí)現(xiàn)

  1. 前端傳遞的參數(shù)格式為:
{  "sort": "userName,updateTime",  "order": "asc,desc"}
  1. 后端接收排序?qū)ο?Sorter,那個(gè)請(qǐng)求查詢(xún)用到自定義排序就繼承該類(lèi):
import io.swagger.annotations.ApiModelProperty;import lombok.Data;/** 1. 基礎(chǔ)排序?qū)ο螅判蜃侄魏团判蚍绞?*/@Datapublic class Sorter{    @ApiModelProperty(value = "排序字段",example = "userName")    private String sort;    @ApiModelProperty(value = "排序方式",example = "asc/desc")    private String order;    /**     * 根據(jù)查詢(xún)條件拼接得到order by語(yǔ)句     * @param sorter 分頁(yè)查詢(xún)條件     * @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))        {            // 駝峰命名轉(zhuǎn)為下劃線(xiàn)            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();    }    /**     * 根據(jù)查詢(xún)條件拼接得到order by語(yǔ)句     * @param sorter 分頁(yè)查詢(xún)條件     * @return String     */    public static String getOrderByStatement(Sorter sorter)    {        String statement = getStatement(sorter);        if (StringUtils.isNotEmpty(statement))        {            return " order by " + statement;        }        else        {            return statement;        }    }}
  1. 處理字段駝峰式的工具類(lèi):
/** 3. 字符串工具類(lèi) 4.  5. @author lcl */public class StringUtils extends org.apache.commons.lang3.StringUtils{    /** 下劃線(xiàn) */    private static final char SEPARATOR = "_";    /**     * * 判斷一個(gè)字符串是否為非空串     *     * @param str String     * @return true:非空串 false:空串     */    public static boolean isNotEmpty(String str)    {        return !isEmpty(str);    }    /**     * 駝峰轉(zhuǎn)下劃線(xiàn)命名     */    public static String toUnderScoreCase(String str)    {        if (str == null)        {            return null;        }        StringBuilder sb = new StringBuilder();        // 前置字符是否大寫(xiě)        boolean preCharIsUpperCase = true;        // 當(dāng)前字符是否大寫(xiě)        boolean curreCharIsUpperCase = true;        // 下一字符是否大寫(xiě)        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. 請(qǐng)求查詢(xún)的入?yún)?duì)象繼承 Sorter排序?qū)ο?
入?yún)?duì)象
  1. Mapper層直接調(diào)用last在sql尾拼接語(yǔ)句方法,將SortergetOrderByStatement(Sorter sorter)方法傳入:
語(yǔ)句拼接

結(jié)果

測(cè)試排序

關(guān)鍵詞:

責(zé)任編輯:

免責(zé)聲明

頭條新聞

精彩推送

新聞推送