Java 根据年号和第几周得到开始时间和结束时间
By:Roy.LiuLast updated:2014-06-05
通常在做与时间相关的查询时,一个通用的做法是放入两个日历控件,一个是开始时间,一个是结束时间,用户在选择时间之后,校验时间合法性之后,就可以查询了,但在做小日本项目时遇到一个很奇葩的查询,这些用户不用开始时间结束时间,而是用这一年的第几周来查询出报表,个人觉得很不习惯,但还得做。
后台保留的时间格式是datetime类型的,而前台给出的条件是 年号 和第几周,比如 2014 年 第 5 周. 这个时候,你需要在后台用 Java 将 它转换成具体的开始时间,结束时间,然后再去数据库查询。转换的具体方法,分享如下 :
运行得到 2014 年第 5 周的开始时间和结束时间:
后台保留的时间格式是datetime类型的,而前台给出的条件是 年号 和第几周,比如 2014 年 第 5 周. 这个时候,你需要在后台用 Java 将 它转换成具体的开始时间,结束时间,然后再去数据库查询。转换的具体方法,分享如下 :
package com.training.controller;
import java.util.Calendar;
public class ConvertDateTest {
public static void main(String[] args) {
ConvertDateTest cd = new ConvertDateTest();
System.out.println("开始时间: " + cd.getStartDayOfWeekNo(2014,5) );
System.out.println("结束时间:" + cd.getEndDayOfWeekNo(2014,5) );
}
/**
* get first date of given month and year
* @param year
* @param month
* @return
*/
public String getFirstDayOfMonth(int year,int month){
String monthStr = month < 10 ? "0" + month : String.valueOf(month);
return year + "-"+monthStr+"-" +"01";
}
/**
* get the last date of given month and year
* @param year
* @param month
* @return
*/
public String getLastDayOfMonth(int year,int month){
Calendar calendar = Calendar.getInstance();
calendar.set(Calendar.YEAR , year);
calendar.set(Calendar.MONTH , month - 1);
calendar.set(Calendar.DATE , 1);
calendar.add(Calendar.MONTH, 1);
calendar.add(Calendar.DAY_OF_YEAR , -1);
return calendar.get(Calendar.YEAR) + "-" + (calendar.get(Calendar.MONTH) + 1) + "-" +
calendar.get(Calendar.DAY_OF_MONTH);
}
/**
* get Calendar of given year
* @param year
* @return
*/
private Calendar getCalendarFormYear(int year){
Calendar cal = Calendar.getInstance();
cal.set(Calendar.DAY_OF_WEEK, Calendar.MONDAY);
cal.set(Calendar.YEAR, year);
return cal;
}
/**
* get start date of given week no of a year
* @param year
* @param weekNo
* @return
*/
public String getStartDayOfWeekNo(int year,int weekNo){
Calendar cal = getCalendarFormYear(year);
cal.set(Calendar.WEEK_OF_YEAR, weekNo);
return cal.get(Calendar.YEAR) + "-" + (cal.get(Calendar.MONTH) + 1) + "-" +
cal.get(Calendar.DAY_OF_MONTH);
}
/**
* get the end day of given week no of a year.
* @param year
* @param weekNo
* @return
*/
public String getEndDayOfWeekNo(int year,int weekNo){
Calendar cal = getCalendarFormYear(year);
cal.set(Calendar.WEEK_OF_YEAR, weekNo);
cal.add(Calendar.DAY_OF_WEEK, 6);
return cal.get(Calendar.YEAR) + "-" + (cal.get(Calendar.MONTH) + 1) + "-" +
cal.get(Calendar.DAY_OF_MONTH);
}
}
运行得到 2014 年第 5 周的开始时间和结束时间:
开始时间: 2014-1-27 结束时间:2014-2-2
From:一号门

COMMENTS