MyBatis Plus之實(shí)現(xiàn)動(dòng)態(tài)排序方式
1、應(yīng)用場(chǎng)景
MyBatis Plus功能很強(qiáng)大,但是對(duì)于前端多個(gè)排序字段并存且自由度高的場(chǎng)景下,服務(wù)端人員很難通過(guò)原來(lái)的MyBatis Plus功能進(jìn)行編碼,所以有了這個(gè)文章。
2、具體思路
通過(guò)前端傳過(guò)來(lái)的參數(shù)對(duì)參數(shù)進(jìn)行轉(zhuǎn)駝峰拼接成order Sql 傳入排序字段
- (存在注入風(fēng)險(xiǎn),自己做好防護(hù))
- (存在注入風(fēng)險(xiǎn),自己做好防護(hù))
- (存在注入風(fēng)險(xiǎn),自己做好防護(hù))
3、具體實(shí)現(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語(yǔ)句 * * @param sorter 分頁(yè)查詢條件 * @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語(yǔ)句 * * @param sorter 分頁(yè)查詢條件 * @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)蛇形,如果項(xiàng)目已經(jīng)有工具,則修改上面代碼)
/** * 3. 字符串工具類 * 4. 5. @author lcl */ public class StringUtil extends org.apache.commons.lang3.StringUtils { /** * 下劃線 */ private static final char SEPARATOR = '_'; /** * * 判斷一個(gè)字符串是否為非空串 * * @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(); // 前置字符是否大寫(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(); } }
c、需要排序的VO直接繼承Sorter
如以下代碼
@Data @ApiModel("醫(yī)生搜索參數(shù)對(duì)象") public class SearchDoctorParams extends Sorter{ @ApiModelProperty("搜索關(guān)鍵字") private String queryKeyword; @ApiModelProperty("科室編號(hào)") 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ī)生特長(zhǎng)標(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é)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot獲取HttpServletRequest的3種方式總結(jié)
這篇文章主要給大家介紹了關(guān)于SpringBoot獲取HttpServletRequest的3種方式,在Spring boot項(xiàng)目中經(jīng)常要用到Servlet的常用對(duì)象如HttpServletRequest request,HttpServletResponse response,HttpSession session,需要的朋友可以參考下2023-08-08SLF4J報(bào)錯(cuò)解決:No SLF4J providers were found的
這篇文章主要介紹了SLF4J報(bào)錯(cuò)解決:No SLF4J providers were found的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-06-06java 中createStatement()方法的實(shí)例詳解
這篇文章主要介紹了java 中createStatement()方法的實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-06-06解決mapper自動(dòng)裝配識(shí)別不了,Could not autowire.No beans&
文章介紹了在使用MyBatisX插件和MybatisPlus自動(dòng)生成代碼后,如何解決Spring Boot項(xiàng)目中自動(dòng)注入`UserMapper`時(shí)報(bào)錯(cuò)的問(wèn)題,主要方法包括在主配置類或啟動(dòng)類上添加`@MapperScan`注解,指定Mapper文件夾所在的包路徑,以及在Mapper類上添加`@Repository`注解2024-11-11在同一個(gè)類中調(diào)用帶有@Transactional注解的方法示例
這篇文章主要為大家介紹了在同一個(gè)類中調(diào)用帶有@Transactional注解的方法示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04SpringBoot核心@SpringBootApplication使用介紹
這篇文章主要介紹了SpringBoot核心@SpringBootApplication的使用,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03MyBatis 實(shí)現(xiàn)數(shù)據(jù)的批量新增和刪除的操作
這篇文章主要介紹了MyBatis 實(shí)現(xiàn)數(shù)據(jù)的批量新增和刪除的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-02-02Java深入了解數(shù)據(jù)結(jié)構(gòu)之棧與隊(duì)列的詳解
這篇文章主要介紹了Java數(shù)據(jù)結(jié)構(gòu)中的棧與隊(duì)列,在Java的時(shí)候,對(duì)于棧與隊(duì)列的應(yīng)用需要熟練的掌握,這樣才能夠確保Java學(xué)習(xí)時(shí)候能夠有扎實(shí)的基礎(chǔ)能力。本文小編就來(lái)詳細(xì)說(shuō)說(shuō)Java中的棧與隊(duì)列,需要的朋友可以參考一下2022-01-01