java中,判断当前时间是否处于某个一个时间段内

今天同事拿了个问题问我,有一个回调工程,会一直查询今日订单表和回调表中的订单数据,然后这条sql今日订单日期是动态的,

 

select * from QYPT_QUERY_GOODS goods,qypt_pay_history_20180512 pay where goods.status=3 

and  goods.form_id=pay.id 

 

比如,今天是2018-05-12,订单表就是qypt_pay_history_20180512 ,如果是2018-05-13,订单表就是qypt_pay_history_20180512 ,今日订单中有30分钟的支付时间,超出就无法支付了,他问我说,如果客户在2018-05-12 23:59下单了,到了第二天,2018-05-13,日期变了,今日订单表也变了,然后就查询不到对应的订单数据了,但是,用户刚刚下的这笔订单有30分中的有效支付时间,相当于到2018-05-13 00:29都是可以支付的,但是日期已经发生改变,无法查询对应的订单信息了,

 

我想了一下,说,你可以判断当前时间是否处于一个时间段内,即(处于 第二天的00:00~00:30),相当与昨天下单的最后支付有效时间,如果处于这个时间段内,你可以执行sql查询昨天的订单,即qypt_pay_history_20180512,然后将查询出来的数据在和qypt_pay_history_20180513进行合并,就可以了,这样就不会丢失数据了

 

这边写下判断当前时间处于一个时间段的代码

 

package cn.com;


import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;


/** 
 * @author 作者:吴林飞 
 * @version 创建时间:2018年5月11日 下午3:02:10 
 * 类说明 :
 */
public class Time_test {
public static void main(String[] args) {
SimpleDateFormat df = new SimpleDateFormat("HH:mm");//设置日期格式
//初始化
    Date nowTime =null;
    Date beginTime = null;
    Date endTime = null;
    try {
    //格式化当前时间格式
    nowTime = df.parse(df.format(new Date()));
        //定义开始时间
        beginTime = df.parse("15:00");
        //定义结束时间
        endTime = df.parse("15:55");
    } catch (Exception e) {
        e.printStackTrace();
    }
    //调用判断方法
    boolean flag = belongCalendar(nowTime, beginTime, endTime);
    //输出为结果
    if(flag){
    //处于规定的时间段内,执行对应的逻辑代码
    System.out.println(flag);
    }else{
    //不处于规定的时间段内,执行对应的逻辑代码
    System.out.println(flag);
    }
   
}


/**
     * 判断时间是否在时间段内
     * @param nowTime
     * @param beginTime
     * @param endTime
     * @return
     */
    public static boolean belongCalendar(Date nowTime, Date beginTime, Date endTime) {
    //设置当前时间
        Calendar date = Calendar.getInstance();
        date.setTime(nowTime);
        //设置开始时间
        Calendar begin = Calendar.getInstance();
        begin.setTime(beginTime);
        //设置结束时间
        Calendar end = Calendar.getInstance();
        end.setTime(endTime);
        //处于开始时间之后,和结束时间之前的判断
        if (date.after(begin) && date.before(end)) {
            return true;
        } else {
            return false;
        }
    }
}

 

  • 5
    点赞
  • 36
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值