欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mybatis-Plus時(shí)間范圍查詢方式詳解

 更新時(shí)間:2022年09月16日 09:34:09   作者:怪?咖@  
這篇文章主要介紹了Mybatis-Plus時(shí)間范圍查詢方式詳解,通過(guò)兩種方式結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

方式一

通過(guò)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ò)!

@DateTimeFormatimport 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)文章

  • Java?File類提供的方法與操作

    Java?File類提供的方法與操作

    Java使用File類來(lái)表示計(jì)算機(jī)系統(tǒng)磁盤文件的對(duì)象類型。File中提供了大量的方法,可以對(duì)文件進(jìn)行增加、刪除、修改、重命名等常規(guī)操作。File類的對(duì)象會(huì)存儲(chǔ)文件自身的信息,例如文件在系統(tǒng)中的存儲(chǔ)目錄、文件大小、文件讀寫權(quán)限等
    2023-03-03
  • 深入解析Java的設(shè)計(jì)模式編程中的模板方法模式

    深入解析Java的設(shè)計(jì)模式編程中的模板方法模式

    這篇文章主要介紹了深入解析Java的設(shè)計(jì)模式編程中的模板方法模式, 模版方法模式由一個(gè)抽象類和一個(gè)(或一組)實(shí)現(xiàn)類通過(guò)繼承結(jié)構(gòu)組成,需要的朋友可以參考下
    2016-02-02
  • springcloud使用Hystrix進(jìn)行微服務(wù)降級(jí)管理

    springcloud使用Hystrix進(jìn)行微服務(wù)降級(jí)管理

    這篇文章主要介紹了springcloud使用Hystrix進(jìn)行微服務(wù)降級(jí)管理,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • 詳解spring mvc 請(qǐng)求轉(zhuǎn)發(fā)和重定向

    詳解spring mvc 請(qǐng)求轉(zhuǎn)發(fā)和重定向

    這篇文章主要介紹了詳解spring mvc 請(qǐng)求轉(zhuǎn)發(fā)和重定向,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-02-02
  • MAC 系統(tǒng)如何使用 Sublime Text 2 直接編譯運(yùn)行 java 代碼

    MAC 系統(tǒng)如何使用 Sublime Text 2 直接編譯運(yùn)行 java 代碼

    這篇文章主要介紹了MAC 系統(tǒng)如何使用 Sublime Text 2 直接編譯運(yùn)行 java 代碼,需要的朋友可以參考下
    2014-10-10
  • 詳解SpringMVC中的@RequestMapping注解

    詳解SpringMVC中的@RequestMapping注解

    這篇文章主要介紹了SpringMVC中@RequestMapping注解,@RequestMapping注解是一個(gè)用來(lái)處理請(qǐng)求地址映射的注解,可用于映射一個(gè)請(qǐng)求或一個(gè)方法,可以用在類或方法上,需要的朋友可以參考下
    2023-07-07
  • 解析Java的Spring框架的BeanPostProcessor發(fā)布處理器

    解析Java的Spring框架的BeanPostProcessor發(fā)布處理器

    這篇文章主要介紹了Java的Spring框架的BeanPostProcessor發(fā)布處理器,Spring是Java的SSH三大web開發(fā)框架之一,需要的朋友可以參考下
    2015-12-12
  • java數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn)順序表示例

    java數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn)順序表示例

    這篇文章主要介紹了java數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn)順序表示例,需要的朋友可以參考下
    2014-03-03
  • SpringBoot整合MybatisPlus的基本應(yīng)用詳解

    SpringBoot整合MybatisPlus的基本應(yīng)用詳解

    MyBatis-Plus (簡(jiǎn)稱 MP)是一個(gè) MyBatis的增強(qiáng)工具,在 MyBatis 的基礎(chǔ)上只做增強(qiáng)不做改變,為 簡(jiǎn)化開發(fā)、提高效率而生,本文將給大家介紹一下SpringBoot整合MybatisPlus的基本應(yīng)用,需要的朋友可以參考下
    2024-05-05
  • Elasticsearch查詢之Match Query示例詳解

    Elasticsearch查詢之Match Query示例詳解

    這篇文章主要為大家介紹了Elasticsearch查詢之Match查詢示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04

最新評(píng)論