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



猜你喜欢

转载自blog.csdn.net/qq_35868412/article/details/80282185