首页 > 其他 > 详细

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

时间:2018-12-20 18:30:17      阅读:168      评论:0      收藏:0      [点我收藏+]

 

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

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!