Mybatis-Plus時(shí)間范圍查詢方式詳解
方式一
通過apply方法,來(lái)實(shí)現(xiàn)時(shí)間范圍查詢,該方法可用于數(shù)據(jù)庫(kù)函數(shù),動(dòng)態(tài)入?yún)⒌膒arams對(duì)應(yīng)前面applySql內(nèi)部的{index}部分,這樣是不會(huì)有sql注入風(fēng)險(xiǎn)的,反之會(huì)有!
apply(boolean condition, String applySql, Object... params)
反例:
queryWrapper.apply(StrUtil.isNotBlank(serviceItemListDto.getStartTime()),
"date_format (create_time,'%Y-%m-%d') >= date_format('" + serviceItemListDto.getEndTime() + "','%Y-%m-%d')")
.apply(StrUtil.isNotBlank(serviceItemListDto.getEndTime()),
"date_format (create_time,'%Y-%m-%d') <= date_format('" + serviceItemListDto.getEndTime() + "','%Y-%m-%d')");
正例:
queryWrapper.apply(serviceItemListDto.getStartTime() != null,
"date_format (create_time,'%Y-%m-%d') >= date_format ({0},'%Y-%m-%d')", serviceItemListDto.getStartTime())
.apply(serviceItemListDto.getEndTime() != null,
"date_format (create_time,'%Y-%m-%d') <= date_format ({0},'%Y-%m-%d')", serviceItemListDto.getEndTime());
;
方式二
除了使用apply還可以使用ge(大于等于 >=)和le(小于等于 <=)
LambdaQueryWrapper<ObsConsultationRequest> qw = new LambdaQueryWrapper<>();
Optional.ofNullable(request.getStartRequestDatetime()).ifPresent(
date -> qw.ge(ObsConsultationRequest::getRequestDatetime, date));
Optional.ofNullable(request.getEndRequestDatetime()).ifPresent(
date -> qw.le(ObsConsultationRequest::getRequestDatetime, date));
請(qǐng)求方式
Get請(qǐng)求params傳參或者Post請(qǐng)求json傳參都是可以的
@ApiModelProperty(value = "開始時(shí)間") private String startTime; @ApiModelProperty(value = "結(jié)束時(shí)間 ") private String endTime;

傳參類型
可以選擇使用String來(lái)接參數(shù),也可以使用Date來(lái)接參數(shù)!Date類型接參數(shù)就要和前端固定傳參格式比如yyyy-MM-dd HH:mm:ss,然后使用@DateTimeFormat格式化,不使用@DateTimeFormat然后使用Date類型接參數(shù)會(huì)報(bào)錯(cuò)!
@DateTimeFormat在import org.springframework.format.annotation.DateTimeFormat;,spring自帶的,不需要引入別的依賴
舉例:設(shè)置了@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")而前端傳的2022-09-13T16:00:00.000Z,這樣是會(huì)報(bào)錯(cuò)的!有點(diǎn)指定參數(shù)格式的意思!
{
"endTime": "2022-09-15 20:00:00",
"startTime": "2022-09-15 00:00:00"
}
public class ServiceItemListDto implements Serializable {
@DateTimeFormat(
pattern = "yyyy-MM-dd HH:mm:ss"
)
private Date startTime;
@DateTimeFormat(
pattern = "yyyy-MM-dd HH:mm:ss"
)
private Date endTime;
public Date getStartTime() {
return startTime;
}
public void setStartTime(Date startTime) {
this.startTime = startTime;
}
public Date getEndTime() {
return endTime;
}
public void setEndTime(Date endTime) {
this.endTime = endTime;
}
}
如果按照年月日查詢,而數(shù)據(jù)庫(kù)當(dāng)中存儲(chǔ)的又有時(shí)分秒,這時(shí)候需要格式化一下數(shù)據(jù)庫(kù)存儲(chǔ)的日期,所以得用第一種方式!精確到時(shí)分秒的條件查詢,可以使用第二種方式!
到此這篇關(guān)于Mybatis-Plus時(shí)間范圍查詢方式詳解的文章就介紹到這了,更多相關(guān)Mybatis-Plus時(shí)間范圍查詢內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
淺談Spring框架中@Autowired和@Resource的區(qū)別
最近review別人代碼的時(shí)候,看到了一些@Autowired不一樣的用法,覺得有些意思,下面這篇文章主要給大家介紹了關(guān)于Spring框架中@Autowired和@Resource區(qū)別的相關(guān)資料,需要的朋友可以參考下2022-10-10
GC調(diào)優(yōu)實(shí)戰(zhàn)之過早提升Premature?Promotion
這篇文章主要為大家介紹了GC調(diào)優(yōu)實(shí)戰(zhàn)之過早提升Premature?Promotion2022-01-01
SpringBoot+Nacos+Kafka微服務(wù)流編排的簡(jiǎn)單實(shí)現(xiàn)
本文主要介紹了SpringBoot+Nacos+Kafka微服務(wù)流編排的簡(jiǎn)單實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08
使用Java自帶的mail?API實(shí)現(xiàn)郵件發(fā)送功能全過程
電子郵件的應(yīng)用非常廣泛,例如在某網(wǎng)站注冊(cè)了一個(gè)賬戶,自動(dòng)發(fā)送一封歡迎郵件,通過郵件找回密碼,自動(dòng)批量發(fā)送活動(dòng)信息等,下面這篇文章主要給大家介紹了關(guān)于如何使用Java自帶的mail?API實(shí)現(xiàn)郵件發(fā)送功能的相關(guān)資料,需要的朋友可以參考下2023-04-04
使用@pathvariable與@requestparam碰到的一些問題及解決
這篇文章主要介紹了使用@pathvariable與@requestparam碰到的一些問題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08
使用Java?Executors創(chuàng)建線程池的9種方法
文章主要介紹了?Java?中Executors類創(chuàng)建線程池的?9?種方法,每種方法都詳細(xì)闡述了實(shí)現(xiàn)原理、源代碼分析、參數(shù)解釋、實(shí)現(xiàn)過程、特性和使用場(chǎng)景,感興趣的小伙伴跟著小編一起來(lái)看看吧2024-11-11
理解Java注解及Spring的@Autowired是如何實(shí)現(xiàn)的
今天通過本文帶領(lǐng)大家學(xué)習(xí)注解的基礎(chǔ)知識(shí),學(xué)習(xí)Spring的@Autowired是怎么實(shí)現(xiàn)的,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2021-07-07

