获取任意两个时间之间的所有天

 

import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Calendar;
import java.util.Date;
import java.util.List;

public class Test {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        String tableName = "user_que_log" ;
        
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
        Date dBegin;
        Date dEnd;
        try {
            dBegin = sdf.parse("2017-01-01");
            dEnd = sdf.parse("2017-12-31");
            List<String> datas = findDates(dBegin, dEnd);
            if(datas != null && datas.size() > 0) {
                /*for(int i=0; i<datas.size(); i++) {
                    System.out.println(datas.get(i));
                }*/
                for(int i=0; i<datas.size(); i++) {
                    System.out.println("ALTER TABLE " + tableName + " DROP IF EXISTS PARTITION (day='"+ datas.get(i) +"');");
                }
            }
        } catch (ParseException e) {
            e.printStackTrace();
        }
        
        

        
    }

    private static List<String> findDates(Date dBegin, Date dEnd) {
          List<String> lDate = new ArrayList<String>();
          SimpleDateFormat sd = new SimpleDateFormat("yyyy-MM-dd");
          lDate.add(sd.format(dBegin));
          Calendar calBegin = Calendar.getInstance();
          // 使用给定的 Date 设置此 Calendar 的时间
          calBegin.setTime(dBegin);
          
          Calendar calEnd = Calendar.getInstance();
          // 使用给定的 Date 设置此 Calendar 的时间
          calEnd.setTime(dEnd);
          
          // 测试此日期是否在指定日期之后
          while (dEnd.after(calBegin.getTime()))
          {
               // 根据日历的规则,为给定的日历字段添加或减去指定的时间量
               calBegin.add(Calendar.DAY_OF_MONTH, 1);
               lDate.add(sd.format(calBegin.getTime()));
          }


        return lDate;
    }

}

 

转载于:https://www.cnblogs.com/chengjianxiaoxue/p/10150523.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值