亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MyBatis Plus之實現(xiàn)動態(tài)排序方式

 更新時間:2024年02月19日 10:51:49   作者:楊章隱  
這篇文章主要介紹了MyBatis Plus之實現(xiàn)動態(tài)排序方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

1、應(yīng)用場景

MyBatis Plus功能很強大,但是對于前端多個排序字段并存且自由度高的場景下,服務(wù)端人員很難通過原來的MyBatis Plus功能進(jìn)行編碼,所以有了這個文章。

2、具體思路

通過前端傳過來的參數(shù)對參數(shù)進(jìn)行轉(zhuǎn)駝峰拼接成order Sql 傳入排序字段

  • (存在注入風(fēng)險,自己做好防護(hù))
  • (存在注入風(fēng)險,自己做好防護(hù))
  • (存在注入風(fēng)險,自己做好防護(hù))

3、具體實現(xiàn)

a、排序類

 
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
 
/**
 * 1. 基礎(chǔ)排序?qū)ο?,包含排序字段和排序方?
 */
@Data
public class Sorter {
 
    @ApiModelProperty(value = "排序字段", example = "userName")
    private String sort;
 
    @ApiModelProperty(value = "排序方式", example = "asc/desc")
    private String order;
 
    /**
     * 根據(jù)查詢條件拼接得到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 (StringUtil.isNotEmpty(sortColumn)) {
            // 駝峰命名轉(zhuǎn)為下劃線
            sort = StringUtil.toUnderScoreCase(sortColumn);
 
            if (sort.contains(",")) {
                sortArray = sort.split(",");
            }
        } else {
            return "";
        }
        if (StringUtil.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ù)查詢條件拼接得到order by語句
     *
     * @param sorter 分頁查詢條件
     * @return String
     */
    public static String getOrderByStatement(Sorter sorter) {
        String statement = getStatement(sorter);
 
        if (StringUtil.isNotEmpty(statement)) {
            return " order by " + statement;
        } else {
            return statement;
        }
    }
}

b、工具類

(主要駝峰轉(zhuǎn)蛇形,如果項目已經(jīng)有工具,則修改上面代碼)

 
/**
 * 3. 字符串工具類
 * 4.  5. @author lcl
 */
public class StringUtil 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);
    }
 
    /**
     * 駝峰轉(zhuǎn)下劃線命名
     */
    public static String toUnderScoreCase(String str) {
        if (str == null) {
            return null;
        }
        StringBuilder sb = new StringBuilder();
        // 前置字符是否大寫
        boolean preCharIsUpperCase = true;
        // 當(dāng)前字符是否大寫
        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();
    }
}

c、需要排序的VO直接繼承Sorter

如以下代碼

 
@Data
@ApiModel("醫(yī)生搜索參數(shù)對象")
public class SearchDoctorParams extends Sorter{
 
    @ApiModelProperty("搜索關(guān)鍵字")
    private String queryKeyword;
    @ApiModelProperty("科室編號")
    private String departmentNo;
    @ApiModelProperty("醫(yī)生名稱")
    private String doctorName;
    @ApiModelProperty("地區(qū)編碼")
    private String areaCode;
    @ApiModelProperty("職稱編碼")
    private String positionCategory;
    @ApiModelProperty("是否有醫(yī)保編碼醫(yī)生")
    private Boolean withInsuranceCode;
    @ApiModelProperty(value = "三甲名醫(yī)  1-是 2-否")
    private Integer isFamousDoctor;
    @ApiModelProperty(value = "醫(yī)生類型(10-全職醫(yī)生,20-兼職醫(yī)生)")
    private Integer doctorType;
 
    @ApiModelProperty(value = "醫(yī)生ids", hidden = true)
    private List<String> doctorIds;
 
 
    @ApiModelProperty(value = "醫(yī)生特長標(biāo)簽")
    @DisplayDictionary(category = "doctor_specialty_tag")
    private String doctorTag;
 
    String orderStr;
}
 
//給orderStr賦值
record.setOrderStr(Sorter.getOrderByStatement(record));
//xml層使用
<choose>
    <when test="params.orderStr != null and params.orderStr != ''">
        ${orderStr}
    </when>
    <otherwise>
        默認(rèn)排序
    </otherwise>
</choose>
//QueryWrapper、LambdaQueryWrapper等直接在最后用last
 
 
basicDataService.getList(new LambdaQueryWrapper<>().last(Sorter.getOrderByStatement(record)));

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • SpringBoot獲取HttpServletRequest的3種方式總結(jié)

    SpringBoot獲取HttpServletRequest的3種方式總結(jié)

    這篇文章主要給大家介紹了關(guān)于SpringBoot獲取HttpServletRequest的3種方式,在Spring boot項目中經(jīng)常要用到Servlet的常用對象如HttpServletRequest request,HttpServletResponse response,HttpSession session,需要的朋友可以參考下
    2023-08-08
  • SpringBoot異步方法捕捉異常詳解

    SpringBoot異步方法捕捉異常詳解

    這篇文章主要為大家詳細(xì)介紹了SpringBoot異步方法捕捉異常,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-09-09
  • JAVA程序員不得不留意的編碼規(guī)范

    JAVA程序員不得不留意的編碼規(guī)范

    這篇文章主要介紹了JAVA程序員不得不留意的編碼規(guī)范,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • SLF4J報錯解決:No SLF4J providers were found的問題

    SLF4J報錯解決:No SLF4J providers were found的

    這篇文章主要介紹了SLF4J報錯解決:No SLF4J providers were found的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • java 中createStatement()方法的實例詳解

    java 中createStatement()方法的實例詳解

    這篇文章主要介紹了java 中createStatement()方法的實例詳解的相關(guān)資料,需要的朋友可以參考下
    2017-06-06
  • 解決mapper自動裝配識別不了,Could not autowire.No beans of‘UserMapper‘type found

    解決mapper自動裝配識別不了,Could not autowire.No beans&

    文章介紹了在使用MyBatisX插件和MybatisPlus自動生成代碼后,如何解決Spring Boot項目中自動注入`UserMapper`時報錯的問題,主要方法包括在主配置類或啟動類上添加`@MapperScan`注解,指定Mapper文件夾所在的包路徑,以及在Mapper類上添加`@Repository`注解
    2024-11-11
  • 在同一個類中調(diào)用帶有@Transactional注解的方法示例

    在同一個類中調(diào)用帶有@Transactional注解的方法示例

    這篇文章主要為大家介紹了在同一個類中調(diào)用帶有@Transactional注解的方法示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • SpringBoot核心@SpringBootApplication使用介紹

    SpringBoot核心@SpringBootApplication使用介紹

    這篇文章主要介紹了SpringBoot核心@SpringBootApplication的使用,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • MyBatis 實現(xiàn)數(shù)據(jù)的批量新增和刪除的操作

    MyBatis 實現(xiàn)數(shù)據(jù)的批量新增和刪除的操作

    這篇文章主要介紹了MyBatis 實現(xiàn)數(shù)據(jù)的批量新增和刪除的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-02-02
  • Java深入了解數(shù)據(jù)結(jié)構(gòu)之棧與隊列的詳解

    Java深入了解數(shù)據(jù)結(jié)構(gòu)之棧與隊列的詳解

    這篇文章主要介紹了Java數(shù)據(jù)結(jié)構(gòu)中的棧與隊列,在Java的時候,對于棧與隊列的應(yīng)用需要熟練的掌握,這樣才能夠確保Java學(xué)習(xí)時候能夠有扎實的基礎(chǔ)能力。本文小編就來詳細(xì)說說Java中的棧與隊列,需要的朋友可以參考一下
    2022-01-01

最新評論