java处理时间的总结(转贴)

/** 
* 有关日期工具类(extends TimeUtil) 
*  
* TimeUtil主要功能有: 
* 1.各种日期类型(字符,util.Date,sql.Date,Calendar等)转换 
* 2.获取指定日期的年份,月份,日份,小时,分,秒,毫秒 
* 3.获取当前/系统日期(指定日期格式) 
* 4.获取字符日期一个月的天数 
* 5.获取指定月份的第一天,最后一天 
*  
* DateUtil主要功能有: 
* 1.日期比较 
* 2.获取2个字符日期的天数差,周数差,月数差,年数差 
* 3.日期添加 
* 4.判断给定日期是不是润年 
*/package com.aimtime.financing.service.util;  
import java.util.Calendar;  
import java.util.Date;  
import java.util.GregorianCalendar;  
import java.text.*;public abstract class TimeUtil {  
 
 
//---当前日期的年,月,日,时,分,秒  
public static Calendar now   = Calendar.getInstance();  
int    year = now.get( Calendar.YEAR );  
int    date = now.get( Calendar.DAY_OF_MONTH );  
int    month = now.get( Calendar.MONTH ) + 1;  
int    hour = now.get( Calendar.HOUR );  
int    min   = now.get( Calendar.MINUTE );  
int    sec   = now.get( Calendar.SECOND );  
 
//-------------------------------日期类型转换---------------------------------------------------------------------------  
/** 
* 字符型日期转化util.Date型日期 
* @Param:p_strDate 字符型日期  
* @param p_format 格式:"yyyy-MM-dd" / "yyyy-MM-dd hh:mm:ss" 
* @Return:java.util.Date util.Date型日期 
* @Throws: ParseException 
* @Author: zhuqx 
* @Date:   2006-10-31 
*/ 
public static java.util.Date toUtilDateFromStrDateByFormat( String p_strDate, String p_format )  
    throws ParseException {  
   java.util.Date l_date = null;  
   java.text.DateFormat df = new java.text.SimpleDateFormat( p_format );  
   if ( p_strDate != null && ( !"".equals( p_strDate ) ) && p_format != null && ( !"".equals( p_format ) ) ) {  
    l_date = df.parse( p_strDate );  
   }  
   return l_date;  
}  
 
 
 
/** 
* 字符型日期转化成sql.Date型日期 
* @param p_strDate    字符型日期 
* @return java.sql.Date sql.Date型日期 
* @throws ParseException  
* @Author: zhuqx 
* @Date:   2006-10-31 
*/ 
public static java.sql.Date toSqlDateFromStrDate( String p_strDate ) throws ParseException {  
   java.sql.Date returnDate = null;  
   java.text.DateFormat sdf = new java.text.SimpleDateFormat();  
   if ( p_strDate != null && ( !"".equals( p_strDate ) ) ) {  
    returnDate = new java.sql.Date( sdf.parse( p_strDate ).getTime() );  
   }  
   return returnDate;  
}  
    
/**  
* util.Date型日期转化指定格式的字符串型日期 
* @param   p_date    Date  
* @param   p_format String  
* 格式1:"yyyy-MM-dd"  
* 格式2:"yyyy-MM-dd hh:mm:ss EE"  
* 格式3:"yyyy年MM月dd日 hh:mm:ss EE"  
* 说明: 年-月-日 时:分:秒 星期 注意MM/mm大小写 
* @return String  
* @Author: zhuqx 
* @Date:   2006-10-31 
*/ 
public static String toStrDateFromUtilDateByFormat( java.util.Date p_utilDate, String p_format ) throws ParseException {  
   String l_result = "";  
   if ( p_utilDate != null ) {  
    SimpleDateFormat sdf = new SimpleDateFormat( p_format );  
    l_result = sdf.format( p_utilDate );  
   }  
   return l_result;  
}  
 
/** 
* util.Date型日期转化转化成Calendar日期 
* @param p_utilDate Date 
* @return Calendar 
* @Author: zhuqx 
* @Date: 2006-10-31 
*/ 
public static Calendar toCalendarFromUtilDate(java.util.Date p_utilDate) {  
   Calendar c = Calendar.getInstance();  
   c.setTime(p_utilDate);  
   return c;  
}  
 
/** 
* util.Date型日期转化sql.Date(年月日)型日期 
* @Param: p_utilDate util.Date型日期 
* @Return: java.sql.Date sql.Date型日期 
* @Author: zhuqx 
* @Date:   2006-10-31 
*/ 
public static java.sql.Date toSqlDateFromUtilDate( java.util.Date p_utilDate ) {  
   java.sql.Date returnDate = null;  
   if ( p_utilDate != null ) {  
    returnDate = new java.sql.Date( p_utilDate.getTime() );  
   }  
   return returnDate;  
}  
 
/** 
* util.Date型日期转化sql.Time(时分秒)型日期 
* @Param: p_utilDate util.Date型日期 
* @Return: java.sql.Time sql.Time型日期 
* @Author: zhuqx 
* @Date:   2006-10-31 
*/ 
public static java.sql.Time toSqlTimeFromUtilDate( java.util.Date p_utilDate ) {  
   java.sql.Time returnDate = null;  
   if ( p_utilDate != null ) {  
    returnDate = new java.sql.Time( p_utilDate.getTime() );  
   }  
   return returnDate;  
}  
 
/** 
* util.Date型日期转化sql.Date(时分秒)型日期 
* @Param: p_utilDate util.Date型日期 
* @Return: java.sql.Timestamp sql.Timestamp型日期 
* @Author: zhuqx 
* @Date:   2006-10-31 
*/ 
public static java.sql.Timestamp toSqlTimestampFromUtilDate( java.util.Date p_utilDate ) {  
   java.sql.Timestamp returnDate = null;  
   if ( p_utilDate != null ) {  
    returnDate = new java.sql.Timestamp( p_utilDate.getTime() );  
   }  
   return returnDate;  
}  
 
/** 
* sql.Date型日期转化util.Date型日期 
* @Param: sqlDate sql.Date型日期 
* @Return: java.util.Date util.Date型日期 
* @Author: zhuqx 
* @Date:   2006-10-31 
*/ 
public static java.util.Date toUtilDateFromSqlDate( java.sql.Date p_sqlDate ) {  
   java.util.Date returnDate = null;  
   if ( p_sqlDate != null ) {  
    returnDate = new java.util.Date( p_sqlDate.getTime() );  
   }  
   return returnDate;  
}  
 
//-----------------获取指定日期的年份,月份,日份,小时,分,秒,毫秒----------------------------  
/**  
* 获取指定日期的年份  
* @param p_date util.Date日期  
* @return int   年份  
* @author zhuqx 
* @Date:   2006-10-31 
*/ 
public static int getYearOfDate( java.util.Date p_date ) {  
   java.util.Calendar c = java.util.Calendar.getInstance();  
   c.setTime( p_date );  
   return c.get( java.util.Calendar.YEAR );  
}  
    
/**  
* 获取指定日期的月份  
* @param p_date util.Date日期  
* @return int   月份  
* @author zhuqx 
* @Date:   2006-10-31 
*/ 
public static int getMonthOfDate( java.util.Date p_date ) {  
   java.util.Calendar c = java.util.Calendar.getInstance();  
   c.setTime( p_date );  
   return c.get( java.util.Calendar.MONTH ) + 1;  
}  
 
/**  
* 获取指定日期的日份  
* @param p_date util.Date日期  
* @return int   日份  
* @author zhuqx 
* @Date:   2006-10-31 
*/ 
public static int getDayOfDate( java.util.Date p_date ) {  
   java.util.Calendar c = java.util.Calendar.getInstance();  
   c.setTime( p_date );  
   return c.get( java.util.Calendar.DAY_OF_MONTH );  
}  
 
/**  
* 获取指定日期的小时  
* @param p_date util.Date日期  
* @return int   日份  
* @author zhuqx 
* @Date:   2006-10-31 
*/ 
public static int getHourOfDate( java.util.Date p_date ) {  
   java.util.Calendar c = java.util.Calendar.getInstance();  
   c.setTime( p_date );  
   return c.get( java.util.Calendar.HOUR_OF_DAY );  
}  
    
/**  
* 获取指定日期的分钟  
* @param p_date util.Date日期  
* @return int   分钟  
* @author zhuqx 
* @Date:   2006-10-31 
*/ 
public static int getMinuteOfDate( java.util.Date p_date ) {  
   java.util.Calendar c = java.util.Calendar.getInstance();  
   c.setTime( p_date );  
   return c.get( java.util.Calendar.MINUTE );  
}  
    
/**  
* 获取指定日期的秒钟  
* @param p_date util.Date日期  
* @return int   秒钟  
* @author zhuqx 
* @Date:   2006-10-31 
*/ 
public static int getSecondOfDate( java.util.Date p_date ) {  
   java.util.Calendar c = java.util.Calendar.getInstance();  
   c.setTime( p_date );  
   return c.get( java.util.Calendar.SECOND );  
}  
    
/**  
* 获取指定日期的毫秒    
* @param p_date util.Date日期  
* @return long   毫秒    
* @author zhuqx 
* @Date:   2006-10-31 
*/ 
public static long getMillisOfDate( java.util.Date p_date ) {  
   java.util.Calendar c = java.util.Calendar.getInstance();  
   c.setTime( p_date );  
   return c.getTimeInMillis();  
}  
 
//-----------------获取当前/系统日期(指定日期格式)-----------------------------------------------------------------------------------  
/** 
* 获取指定日期格式当前日期的字符型日期 
* @param p_format 日期格式 
* 格式1:"yyyy-MM-dd"  
* 格式2:"yyyy-MM-dd hh:mm:ss EE"  
* 格式3:"yyyy年MM月dd日 hh:mm:ss EE"  
* 说明: 年-月-日 时:分:秒 星期 注意MM/mm大小写 
* @return String 当前时间字符串 
* @author zhuqx 
* @Date:   2006-10-31 
*/ 
public static String getNowOfDateByFormat( String p_format ) {  
   Date d = new Date();  
   SimpleDateFormat sdf = new SimpleDateFormat( p_format );  
   String dateStr = sdf.format( d );  
   return dateStr;  
}  
 
/** 
* 获取指定日期格式系统日期的字符型日期 
* @param p_format 日期格式 
* 格式1:"yyyy-MM-dd"  
* 格式2:"yyyy-MM-dd hh:mm:ss EE"  
* 格式3:"yyyy年MM月dd日 hh:mm:ss EE"  
* 说明: 年-月-日 时:分:秒 星期 注意MM/mm大小写 
* @return String 系统时间字符串 
* @author zhuqx 
* @Date:   2006-10-31 
*/ 
public static String getSystemOfDateByFormat( String p_format ) {  
   long time = System.currentTimeMillis();  
   Date d2 = new Date();  
   Date d = new Date( time );  
   SimpleDateFormat sdf = new SimpleDateFormat( p_format );  
   String dateStr = sdf.format( d );  
   return dateStr;  
}  
 
/** 
* 获取字符日期一个月的天数 
* @param p_date 
* @return 天数 
* @author zhuqx 
*/ 
public static long getDayOfMonth( Date p_date ) throws ParseException {  
   int year = getYearOfDate(p_date);  
   int month = getMonthOfDate( p_date )-1;  
   int day = getDayOfDate( p_date );  
   int hour = getHourOfDate( p_date );  
   int minute = getMinuteOfDate( p_date );  
   int second = getSecondOfDate( p_date );  
   Calendar l_calendar = new GregorianCalendar(year,month,day,hour,minute,second);  
   return l_calendar.getActualMaximum( l_calendar.DAY_OF_MONTH );  
}  
 
// -----------------获取指定月份的第一天,最后一天 ---------------------------------------------------------------------------  
/**  
* 获取指定月份的第一天  
* @param p_strDate 指定月份 
* @param p_formate 日期格式 
* @return String 时间字符串 
* @author zhuqx 
* @Date:   2006-10-31 
*/ 
public static String getDateOfMonthBegin( String p_strDate, String p_format ) throws ParseException {  
   java.util.Date date = toUtilDateFromStrDateByFormat( p_strDate,p_format );  
   return toStrDateFromUtilDateByFormat( date,"yyyy-MM" ) + "-01";  
}  
    
/**  
* 获取指定月份的最后一天  
* @param p_strDate 指定月份 
* @param p_formate 日期格式 
* @return String 时间字符串 
* @author zhuqx 
* @Date:   2006-10-31 
*/ 
public static String getDateOfMonthEnd( String p_strDate, String p_format ) throws ParseException {  
   java.util.Date date = toUtilDateFromStrDateByFormat( getDateOfMonthBegin( p_strDate,p_format ),p_format );  
   Calendar calendar = Calendar.getInstance();  
   calendar.setTime( date );  
   calendar.add( Calendar.MONTH,1 );  
   calendar.add( Calendar.DAY_OF_YEAR,-1 );  
   return toStrDateFromUtilDateByFormat( calendar.getTime(),p_format );  
}  
 
}package com.aimtime.financing.service.util;import java.text.ParseException;  
import java.text.SimpleDateFormat;  
import java.util.Calendar;  
import java.util.Date;  
import java.util.GregorianCalendar;import org.apache.log4j.Logger;/** 
* @Functionality: 有关日期工具类 
*/ 
public class DateUtil extends TimeUtil {  
/** 
* Logger for this class 
*/ 
private static final Logger     logger = Logger.getLogger( DateUtil.class );  
 
 
/** 日期转化 */ 
private static final SimpleDateFormat sdf   = new SimpleDateFormat( "yyyy-MM-dd" );  
 
/** 
* @Functionality: 构造函数 
*/ 
public DateUtil() {}  
    
//----------------------日期计算---------------------------------------------------------------------------------  
 
/** 
* 是否开始日期在结束日期之前(不包括相等) 
* @param p_startDate 
* @param p_endDate 
* @return boolean 在结束日期前:ture;否则:false 
* @author zhuqx 
* @Date:   2006-10-31 
*/ 
public static boolean isStartDateBeforeEndDate( Date p_startDate, Date p_endDate ) throws ParseException {  
   long l_startTime = getMillisOfDate( p_startDate );  
   long l_endTime = getMillisOfDate( p_endDate );  
   return ( l_startTime - l_endTime > (long) 0 ) ? true : false;  
}  
 
/** 
* 获取2个字符日期的天数差 
* @param p_startDate 
* @param p_endDate 
* @return 天数差 
* @author zhuqx 
* @Date:   2006-10-31 
*/ 
public static long getDaysOfTowDiffDate( String p_startDate, String p_endDate ) throws ParseException {  
    
   Date l_startDate = toUtilDateFromStrDateByFormat( p_startDate,"yyyy-MM-dd");  
   Date l_endDate = toUtilDateFromStrDateByFormat( p_endDate, "yyyy-MM-dd");  
   long l_startTime = getMillisOfDate( l_startDate );  
   long l_endTime = getMillisOfDate( l_endDate );  
   long betweenDays = (long) ( ( l_endTime - l_startTime ) / ( 1000 * 60 * 60 * 24 ) );  
   return betweenDays;  
}  
 
/** 
* 获取2个字符日期的周数差 
* @param p_startDate 
* @param p_endDate 
* @return 周数差 
* @author zhuqx 
* @Date:   2006-10-31 
*/ 
public static long getWeeksOfTowDiffDate( String p_startDate, String p_endDate ) throws ParseException {  
   return getDaysOfTowDiffDate(p_startDate,p_endDate)/7;  
}  
 
/** 
* 获取2个字符日期的月数差 
* @param p_startDate 
* @param p_endDate 
* @return 月数差 
* @author zhuqx 
* @Date:   2006-10-31 
*/ 
public static long getMonthsOfTowDiffDate( String p_startDate, String p_endDate ) throws ParseException {  
   return getDaysOfTowDiffDate(p_startDate,p_endDate)/30;  
}  
/** 
* 获取2个字符日期的年数差 
* @param p_startDate 
* @param p_endDate 
* @return 年数差 
* @author zhuqx 
* @Date:   2006-10-31 
*/ 
public static long getYearsOfTowDiffDate( String p_startDate, String p_endDate ) throws ParseException {  
   return getDaysOfTowDiffDate(p_startDate,p_endDate)/365;  
}  
 
/** 
* 在给定的日期基础上添加年,月,日、时,分,秒 
* 例如要再2006-10-21(uitl日期)添加3个月,并且格式化为yyyy-MM-dd格式, 
* 这里调用的方式为 addDate(2006-10-21,3,Calendar.MONTH,"yyyy-MM-dd") 
* @param p_startDate 给定的日期 
* @param p_count 时间的数量 
* @param p_field 添加的域 
* @param p_format 时间转化格式,例如:yyyy-MM-dd hh:mm:ss 或者yyyy-mm-dd等 
* @return 添加后格式化的时间 
* @Date:   2006-10-31 
*/ 
public static String addDate(Date p_startDate,int p_count,int p_field,String p_format)throws ParseException {  
    
   //年,月,日、时,分,秒  
   int l_year = getYearOfDate(p_startDate);  
   int l_month = getMonthOfDate( p_startDate )-1;  
   int l_day = getDayOfDate( p_startDate );  
   int l_hour = getHourOfDate( p_startDate );  
   int l_minute = getMinuteOfDate( p_startDate );  
   int l_second = getSecondOfDate( p_startDate );  
   Calendar l_calendar = new GregorianCalendar(l_year,l_month,l_day,l_hour,l_minute,l_second);  
   l_calendar.add(p_field,p_count);  
   return toStrDateFromUtilDateByFormat(l_calendar.getTime(),p_format);  
}  
 
/** 
* 判断给定日期是不是润年 
* @param p_date 给定日期  
* @return boolean 如果给定的年份为闰年,则返回 true;否则返回 false。 
* @Date: 2006-10-31 
*/ 
   public static boolean isLeapYear(Date p_date) {  
     int l_year = getYearOfDate( p_date );  
     GregorianCalendar l_calendar = new GregorianCalendar();  
     return l_calendar.isLeapYear( l_year );  
   }  
     
}package com.aimtime.financing.service.util;import java.text.ParseException;  
import java.util.Calendar;  
import java.util.Date;import junit.framework.TestCase;import org.apache.log4j.Logger;public class DateUtilTest extends TestCase {  
/** 
* Logger for this class 
*/ 
private static final Logger logger = Logger.getLogger( DateUtilTest.class );  
 
DateUtil dateUtil;  
protected void setUp() throws Exception {  
   logger.debug( "setUp() - start" );  
    
   super.setUp();  
   dateUtil = new DateUtil();  
    
   logger.debug( "setUp() - end" );  
}  
 
 
protected void tearDown() throws Exception {  
   logger.debug( "tearDown() - start" );  
    
   super.tearDown();  
    
   logger.debug( "tearDown() - end" );  
}  
 
/** 
* 获取2个字符日期的天数差 
* @param p_startDate 
* @param p_endDate 
* @return 天数差 
* @author zhuqx 
*/ 
public void testGetDayOfTowDiffDate() throws ParseException {  
   logger.debug( "testGetDayOfTowDiffDate() - start" );  
    
   String startDate = "2005-05-01";  
   String endDate = "2006-09-30";  
   long day = dateUtil.getDaysOfTowDiffDate( startDate,endDate );  
   logger.debug( "day=========" + day);  
   logger.debug( "week=========" + day/7);  
   logger.debug( "month=========" + day/30);  
   logger.debug( "year=========" + day/365);  
   logger.debug( "testGetDayOfTowDiffDate() - end" );  
}  
/** 
* 获取字符日期一个月的天数 
* @param p_date 
* @return 天数 
* @author zhuqx 
*/ 
public void atestGetDayOfMonth() throws ParseException {  
   logger.debug( "testGetDayOfTowDiffDate() - start" );  
    
   String l_date = "2006-02-01";  
   String l_format = "yyyy-MM-dd";  
   long day = dateUtil.getDayOfMonth( dateUtil.toUtilDateFromStrDateByFormat( l_date,l_format ) );  
   logger.debug( "day=========" + day);  
   logger.debug( "testGetDayOfTowDiffDate() - end" );  
}  
 
//-------------------------------日期转换---------------------------------------------------------------------------  
/** 
* 字符串型转化util.Date 
* @Param: p_strDate 字符串型日期 
* @Return: java.util.Date util.Date 
* @Throws: ParseException 
* @Author: zhuqx 
* @Date:   2006-10-31 
*/ 
public void atestToUtilDateByFormat() throws ParseException {  
   logger.debug( "testGetDayOfTowDiffDate() - start" );  
    
   String l_date = "2005-05-01";  
   Date day = dateUtil.toUtilDateFromStrDateByFormat( l_date,"yyyy-MM-dd" );  
   logger.debug( "java.util.Date =========" + day);  
    
   logger.debug( "testGetDayOfTowDiffDate() - end" );  
}  
/** 
* 字符型日期转化成sql.Date型日期 
* @param p_strDate    字符型日期 
* @return java.sql.Date sql.Date型日期 
* @throws ParseException  
* @author shizhuoyang 
*/ 
public void atestToSqlDatet() throws ParseException {  
   logger.debug( "testToSqlDatet() - start" );  
    
   String l_date = "2005-05-01";  
   Date day = dateUtil.toSqlDateFromStrDate( l_date );  
   logger.debug( "java.sql.Date=========" + day);  
    
   logger.debug( "testToSqlDatet() - end" );  
}  
/**  
* util.Date型日期转化指定的格式字符串型 
* @param   p_date    Date  
* @param   p_format String  
*    格式:"yyyy-MM-dd" / "yyyy-MM-dd hh:mm:ss EE" 年-月-日 时:分:秒 星期 注意MM/mm大小写 
* @return String  
* @Author: zhuqx 
* @Date:   2006-10-31 
*/   
public void atestToStrDateByFormat() throws ParseException {  
   logger.debug( "testToStrDateByFormat() - start" );  
    
   java.util.Date l_date = new java.util.Date();  
   String day = dateUtil.toStrDateFromUtilDateByFormat( l_date,"yyyy-MM-dd" );  
   String day2 = dateUtil.toStrDateFromUtilDateByFormat( l_date,"yyyy-MM-dd hh:mm:ss EE" );  
   logger.debug( "string-Date-yyyy-MM-dd=========" + day);  
   logger.debug( "string-Date-yyyy-MM-dd hh:mm:ss=========" + day2);  
    
   logger.debug( "testToStrDateByFormat() - end" );  
}  
/** 
* util.Date型日期转化sql.Date型日期 
* @Param: p_utilDate util.Date型日期 
* @Return: java.sql.Date sql.Date型日期 
* @Author: zhuqx 
* @Date:   2006-10-31 
*/ 
public void atestToSqlDateFromUtilDate() throws ParseException {  
   logger.debug( "testToStrDateByFormat() - start" );  
    
   java.util.Date l_date = new java.util.Date();  
   java.sql.Date day = dateUtil.toSqlDateFromUtilDate( l_date);  
   logger.debug( "java.sql.Date-=========" + day);  
    
   logger.debug( "testToStrDateByFormat() - end" );  
}  
/** 
* sql.Date型日期转化util.Date型日期 
* @Param: sqlDate sql.Date型日期 
* @Return: java.util.Date util.Date型日期 
* @Author: zhuqx 
* @Date:   2006-10-31 
*/ 
public void atestToUtilDateFromSqlDate() throws ParseException {  
   logger.debug( "testToStrDateByFormat() - start" );  
    
   java.sql.Date l_date = dateUtil.toSqlDateFromStrDate("2005-05-01");  
   java.util.Date date = dateUtil.toUtilDateFromSqlDate( l_date);  
   logger.debug( "java.util.Date-=========" + date);  
    
   logger.debug( "testToStrDateByFormat() - end" );  
}  
 
 
//-----------------获取日期(各种日期格式)-----------------------------------------------------------------------------------  
/** 
* 获取当前日期的字符化处理  
* @param p_format 日期格式 
* @return String 当前时间字符串 
* @author zhuqx 
* @Date:   2006-10-31 
*/ 
public void atestGetNowOfDateByFormat() throws ParseException {  
   logger.debug( "testGetNowOfDate() - start" );  
   //yyyy年MM月dd日 hh:mm:ss EE  
   String date = dateUtil.getNowOfDateByFormat( "yyyyMM" );  
   logger.debug( "java.util.Date-=========" + date);  
    
   logger.debug( "testGetNowOfDate() - end" );  
}  
 
/** 
* 获取指定日期格式系统日期的字符型日期 
* @param p_format 日期格式 
* 格式1:"yyyy-MM-dd"  
* 格式2:"yyyy-MM-dd hh:mm:ss EE"  
* 格式3:"yyyy年MM月dd日 hh:mm:ss EE"  
* 说明: 年-月-日 时:分:秒 星期 注意MM/mm大小写 
* @return String 系统时间字符串 
* @author zhuqx 
* @Date:   2006-10-31 
*/ 
public void atestGetSystemOfDateByFormat() throws ParseException {  
   logger.debug( "testGetSystemOfDateByFormat() - start" );  
   //yyyy年MM月dd日 hh:mm:ss EE  
   String date = dateUtil.getSystemOfDateByFormat( "yyyyMM" );  
   logger.debug( "java.util.Date-=========" + date);  
    
   logger.debug( "testGetSystemOfDateByFormat() - end" );  
}  
 
/**  
* 获取指定月份的第一天  
* @param p_strdate 指定月份 
* @param p_formate 日期格式 
* @return String 时间字符串 
* @author zhuqx 
* @Date:   2006-10-31 
*/   
public void atestGetMonthBegin() throws ParseException {  
   logger.debug( "testGetMonthBegin() - start" );  
   //yyyy年MM月dd日 hh:mm:ss EE  
   String l_strDate = "2005-09-11";  
   String l_formate = "yyyy-MM-dd";  
   String date = dateUtil.getDateOfMonthBegin( l_strDate,l_formate );  
   logger.debug( "java.util.Date-=========" + date);  
    
   logger.debug( "testGetMonthBegin() - end" );  
}  
 
/**  
* 取得指定月份的最后一天  
* @param p_strDate 指定月份 
* @param p_formate 日期格式 
* @return String 时间字符串 
* @author zhuqx 
* @Date:   2006-10-31 
*/   
public void atestGetMonthEnd() throws ParseException {  
   logger.debug( "testGetMonthBegin() - start" );  
   //yyyy年MM月dd日 hh:mm:ss EE  
   String l_strDate = "2006-02-11";  
   String l_formate = "yyyy-MM-dd";  
   String date = dateUtil.getDateOfMonthEnd( l_strDate,l_formate );  
   logger.debug( "java.util.Date-=========" + date);  
    
   logger.debug( "testGetMonthBegin() - end" );  
}  
 
/**  
* 获取指定日期的年份,月份,日份,小时,分,秒,毫秒 
* @param p_date util.Date日期  
* @return int   年份  
* @author zhuqx 
* @Date:   2006-10-31 
*/   
public void atestGetYearOfDate() throws ParseException {  
   logger.debug( "testGetMonthBegin() - start" );  
   //yyyy年MM月dd日 hh:mm:ss EE  
   String l_strDate = "2004-02-11 08:25:15";  
   String l_format = "yyyy-MM-dd hh:mm:ss";  
   int year = dateUtil.getYearOfDate( dateUtil.toUtilDateFromStrDateByFormat( l_strDate,l_format ));  
   int month = dateUtil.getMonthOfDate( dateUtil.toUtilDateFromStrDateByFormat( l_strDate,l_format ));  
   int day = dateUtil.getDayOfDate( dateUtil.toUtilDateFromStrDateByFormat( l_strDate,l_format ));  
   int hour = dateUtil.getHourOfDate( dateUtil.toUtilDateFromStrDateByFormat( l_strDate,l_format ));  
   int minute = dateUtil.getMinuteOfDate( dateUtil.toUtilDateFromStrDateByFormat( l_strDate,l_format ));  
   int second = dateUtil.getSecondOfDate( dateUtil.toUtilDateFromStrDateByFormat( l_strDate,l_format ));  
   long millis = dateUtil.getMillisOfDate( dateUtil.toUtilDateFromStrDateByFormat( l_strDate,l_format ));  
    
   logger.debug( "year==========" + year);  
   logger.debug( "month==========" + month);  
   logger.debug( "day==========" + day);  
   logger.debug( "hour==========" + hour);  
   logger.debug( "minute==========" + minute);  
   logger.debug( "second==========" + second);  
   logger.debug( "millis==========" + millis);  
    
   logger.debug( "testGetMonthBegin() - end" );  
}  
 
/** 
* 是否开始日期在结束日期之前 
* @param p_startDate 
* @param p_endDate 
* @return boolean 在结束日期前:ture;否则:false 
* @author zhuqx 
*/ 
public void atestIsStartDateBeforeEndDate() throws ParseException {  
   Date l_startDate = dateUtil.toUtilDateFromStrDateByFormat( "2005-02-11","yyyy-MM-dd" );  
   Date l_endDate = dateUtil.toUtilDateFromStrDateByFormat( "2005-02-11","yyyy-MM-dd" );  
   boolean isBofore = dateUtil.isStartDateBeforeEndDate(l_startDate,l_endDate );  
   logger.debug( "isBofore=="+ isBofore);  
}  
 
/** 
* 在当前的时间基础上添加月、天、或者其他 
* 例如添加3个月,并且格式化为yyyy-MM-dd格式, 
* 这里调用的方式为addMonth(3,Calendar.MONTH,"yyyy-MM-dd") 
* @param p_count 时间的数量 
* @param p_field 添加的域 
* @param p_format 时间转化格式,例如:yyyy-MM-dd hh:mm:ss 或者yyyy-mm-dd等 
* @return 添加后格式化的时间 
* @Date:   2006-10-31 
*/ 
public void atestAddDate() throws ParseException {  
   Date l_startDate = dateUtil.toUtilDateFromStrDateByFormat( "2006-02-27 07:59:59","yyyy-MM-dd hh:mm:ss" );  
   int l_count = 2;  
//   int l_field = Calendar.YEAR;  
//   int l_field = Calendar.MONTH;  
   int l_field = Calendar.DATE;  
//   int l_field = Calendar.HOUR;  
//   int l_field = Calendar.MINUTE;  
//   int l_field = Calendar.SECOND;  
   String l_format = "yyyy-MM-dd hh:mm:ss";  
   String date = this.dateUtil.addDate( l_startDate,l_count,l_field,l_format );  
   logger.debug( "addDate============"+date );  
}  
 
/** 
* 判断给定日期是不是润年 
* @param p_date 给定日期  
* @return boolean 如果给定的年份为闰年,则返回 true;否则返回 false。 
* @Date: 2006-10-31 
*/ 
public void atestIsLeapYear() throws ParseException {  
    
   Date l_date = dateUtil.toUtilDateFromStrDateByFormat( "2000-01-25","yyyy-MM-dd" );  
   boolean isLeap = dateUtil.isLeapYear( l_date );  
   logger.debug( "isLeapYear="+ isLeap );  
}  
 
 
}  

你可能感兴趣的:(java,sql,C++,c,C#)