Mybatis-Plus时间范围查询方式详解

2023-05-16 0 1,035

目录

方式

通过apply方法来实现时间范围查询,该方法可用于数据库函数动态入参的params对应前面applySql内部的{index}部分,这样是不会有sql注入风险的,反之会有!

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));

请求方式

Get请求params传参或者Post请求json传参都是可以的

@ApiModelProperty(value = \"开始时间\")
private String startTime;
@ApiModelProperty(value = \"结束时间 \")
private String endTime;

Mybatis-Plus时间范围查询方式详解

传参类型

可以选择使用String来接参数,也可以使用Date来接参数!Date类型接参数就要和前端固定传参格式比如yyyy-MM-dd HH:mm:ss,然后使用@DateTimeFormat格式化,不使用@DateTimeFormat然后使用Date类型接参数会报错!

@DateTimeFormatimport org.springframework.format.annotation.DateTimeFormat;,spring自带的,不需要引入别的依赖

举例:设置了@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")而前端传的2022-09-13T16:00:00.000Z,这样是会报错的!有点指定参数格式的意思!

{
  \"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;
    }
}

如果按照年月日查询,而数据库当中存储的又有时分秒,这时候需要格式化一下数据库存储的日期,所以得用第一种方式!精确到时分秒的条件查询,可以使用第二种方式!

资源下载此资源下载价格为1小猪币,终身VIP免费,请先
由于本站资源来源于互联网,以研究交流为目的,所有仅供大家参考、学习,不存在任何商业目的与商业用途,如资源存在BUG以及其他任何问题,请自行解决,本站不提供技术服务! 由于资源为虚拟可复制性,下载后不予退积分和退款,谢谢您的支持!如遇到失效或错误的下载链接请联系客服QQ:442469558

:本文采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可, 转载请附上原文出处链接。
1、本站提供的源码不保证资源的完整性以及安全性,不附带任何技术服务!
2、本站提供的模板、软件工具等其他资源,均不包含技术服务,请大家谅解!
3、本站提供的资源仅供下载者参考学习,请勿用于任何商业用途,请24小时内删除!
4、如需商用,请购买正版,由于未及时购买正版发生的侵权行为,与本站无关。
5、本站部分资源存放于百度网盘或其他网盘中,请提前注册好百度网盘账号,下载安装百度网盘客户端或其他网盘客户端进行下载;
6、本站部分资源文件是经压缩后的,请下载后安装解压软件,推荐使用WinRAR和7-Zip解压软件。
7、如果本站提供的资源侵犯到了您的权益,请邮件联系: 442469558@qq.com 进行处理!

猪小侠源码-最新源码下载平台 Java教程 Mybatis-Plus时间范围查询方式详解 https://www.20zxx.cn/705448/xuexijiaocheng/javajc.html

猪小侠源码,优质资源分享网

常见问题
  • 本站所有资源版权均属于原作者所有,均只能用于参考学习,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担
查看详情
  • 最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,建议提前注册好百度网盘账号,使用百度网盘客户端下载
查看详情

相关文章

官方客服团队

为您解决烦忧 - 24小时在线 专业服务