今天同事拿了个问题问我,有一个回调工程,会一直查询今日订单表和回调表中的订单数据,然后这条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;
}
}
}