posts - 4,  comments - 1,  trackbacks - 0
  2007年10月18日
  /**
     * 取得指定月份的第一天
     *
     * @param strdate String
     * @return String
     */
    public String getMonthBegin(String strdate)
    {
        java.util.Date date = parseFormatDate(strdate);
        return formatDateByFormat(date,"yyyy-MM") + "-01";
    }

    /**
     * 取得指定月份的最后一天
     *
     * @param strdate String
     * @return String
     */
    public String getMonthEnd(String strdate)
    {
        java.util.Date date = parseFormatDate(getMonthBegin(strdate));
        Calendar calendar = Calendar.getInstance();
        calendar.setTime(date);
        calendar.add(Calendar.MONTH,1);
        calendar.add(Calendar.DAY_OF_YEAR, -1);
        return formatDate(calendar.getTime());
    }

    /**
     * 常用的格式化日期
     *
     * @param date Date
     * @return String
     */
    public String formatDate(java.util.Date date)
    {
        return formatDateByFormat(date,"yyyy-MM-dd");
    }

    /**
     * 以指定的格式来格式化日期
     *
     * @param date Date
     * @param format String
     * @return String
     */
    public String formatDateByFormat(java.util.Date date,String format)
    {
        String result = "";
        if(date != null)
        {
            try
            {
                SimpleDateFormat sdf = new SimpleDateFormat(format);
                result = sdf.format(date);
            }
            catch(Exception ex)
            {
                LOGGER.info("date:" + date);
                ex.printStackTrace();
            }
        }
        return result;
    }

 

/**
 * 日期操作
 *
 * @author xxx
 * @version 2.0 jdk1.4.0 tomcat5.1.0 * Updated Date:2005/03/10
 */
public class DateUtil {
 /**
  * 格式化日期
  *
  * @param dateStr
  *            字符型日期
  * @param format
  *            格式
  * @return 返回日期
  */
 public static java.util.Date parseDate(String dateStr, String format) {
  java.util.Date date = null;
  try {
   java.text.DateFormat df = new java.text.SimpleDateFormat(format);
   String dt=Normal.parse(dateStr).replaceAll(
     "-", "/");
   if((!dt.equals(""))&&(dt.length()<format.length())){
    dt+=format.substring(dt.length()).replaceAll("[YyMmDdHhSs]","0");
   }
   date = (java.util.Date) df.parse(dt);
  } catch (Exception e) {
  }
  return date;
 }

 public static java.util.Date parseDate(String dateStr) {
  return parseDate(dateStr, "yyyy/MM/dd");
 }

 public static java.util.Date parseDate(java.sql.Date date) {
  return date;
 }
 
 public static java.sql.Date parseSqlDate(java.util.Date date) {
  if (date != null)
   return new java.sql.Date(date.getTime());
  else
   return null;
 }

 public static java.sql.Date parseSqlDate(String dateStr, String format) {
  java.util.Date date = parseDate(dateStr, format);
  return parseSqlDate(date);
 }

 public static java.sql.Date parseSqlDate(String dateStr) {
  return parseSqlDate(dateStr, "yyyy/MM/dd");
 }

 
 public static java.sql.Timestamp parseTimestamp(String dateStr,
   String format) {
  java.util.Date date = parseDate(dateStr, format);
  if (date != null) {
   long t = date.getTime();
   return new java.sql.Timestamp(t);
  } else
   return null;
 }

 public static java.sql.Timestamp parseTimestamp(String dateStr) {
  return parseTimestamp(dateStr, "yyyy/MM/dd HH:mm:ss");
 }

 /**
  * 格式化输出日期
  *
  * @param date
  *            日期
  * @param format
  *            格式
  * @return 返回字符型日期
  */
 public static String format(java.util.Date date, String format) {
  String result = "";
  try {
   if (date != null) {
    java.text.DateFormat df = new java.text.SimpleDateFormat(format);
    result = df.format(date);
   }
  } catch (Exception e) {
  }
  return result;
 }

 public static String format(java.util.Date date) {
  return format(date, "yyyy/MM/dd");
 }

 /**
  * 返回年份
  *
  * @param date
  *            日期
  * @return 返回年份
  */
 public static int getYear(java.util.Date date) {
  java.util.Calendar c = java.util.Calendar.getInstance();
  c.setTime(date);
  return c.get(java.util.Calendar.YEAR);
 }

 /**
  * 返回月份
  *
  * @param date
  *            日期
  * @return 返回月份
  */
 public static int getMonth(java.util.Date date) {
  java.util.Calendar c = java.util.Calendar.getInstance();
  c.setTime(date);
  return c.get(java.util.Calendar.MONTH) + 1;
 }

 /**
  * 返回日份
  *
  * @param date
  *            日期
  * @return 返回日份
  */
 public static int getDay(java.util.Date date) {
  java.util.Calendar c = java.util.Calendar.getInstance();
  c.setTime(date);
  return c.get(java.util.Calendar.DAY_OF_MONTH);
 }

 /**
  * 返回小时
  *
  * @param date
  *            日期
  * @return 返回小时
  */
 public static int getHour(java.util.Date date) {
  java.util.Calendar c = java.util.Calendar.getInstance();
  c.setTime(date);
  return c.get(java.util.Calendar.HOUR_OF_DAY);
 }

 /**
  * 返回分钟
  *
  * @param date
  *            日期
  * @return 返回分钟
  */
 public static int getMinute(java.util.Date date) {
  java.util.Calendar c = java.util.Calendar.getInstance();
  c.setTime(date);
  return c.get(java.util.Calendar.MINUTE);
 }

 /**
  * 返回秒钟
  *
  * @param date
  *            日期
  * @return 返回秒钟
  */
 public static int getSecond(java.util.Date date) {
  java.util.Calendar c = java.util.Calendar.getInstance();
  c.setTime(date);
  return c.get(java.util.Calendar.SECOND);
 }

 /**
  * 返回毫秒
  *
  * @param date
  *            日期
  * @return 返回毫秒
  */
 public static long getMillis(java.util.Date date) {
  java.util.Calendar c = java.util.Calendar.getInstance();
  c.setTime(date);
  return c.getTimeInMillis();
 }

 /**
  * 返回字符型日期
  *
  * @param date
  *            日期
  * @return 返回字符型日期
  */
 public static String getDate(java.util.Date date) {
  return format(date, "yyyy/MM/dd");
 }

 /**
  * 返回字符型时间
  *
  * @param date
  *            日期
  * @return 返回字符型时间
  */
 public static String getTime(java.util.Date date) {
  return format(date, "HH:mm:ss");
 }

 /**
  * 返回字符型日期时间
  *
  * @param date
  *            日期
  * @return 返回字符型日期时间
  */
 public static String getDateTime(java.util.Date date) {
  return format(date, "yyyy/MM/dd HH:mm:ss");
 }

 /**
  * 日期相加
  *
  * @param date
  *            日期
  * @param day
  *            天数
  * @return 返回相加后的日期
  */
 public static java.util.Date addDate(java.util.Date date, int day) {
  java.util.Calendar c = java.util.Calendar.getInstance();
  c.setTimeInMillis(getMillis(date) + ((long) day) * 24 * 3600 * 1000);
  return c.getTime();
 }

 /**
  * 日期相减
  *
  * @param date
  *            日期
  * @param date1
  *            日期
  * @return 返回相减后的日期
  */
 public static int diffDate(java.util.Date date, java.util.Date date1) {
  return (int) ((getMillis(date) - getMillis(date1)) / (24 * 3600 * 1000));
 } 
}

 

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);

 

 

import java.sql.Timestamp;
import java.text.SimpleDateFormat;
import java.util.*;


public class ManageWeek {
 //判断两个日期是否在同一周
 boolean isSameWeekDates(Date date1, Date date2) {
  Calendar cal1 = Calendar.getInstance();
  Calendar cal2 = Calendar.getInstance();
  cal1.setTime(date1);
  cal2.setTime(date2);
  int subYear = cal1.get(Calendar.YEAR) - cal2.get(Calendar.YEAR);
  if (0 == subYear) {
    if (cal1.get(Calendar.WEEK_OF_YEAR) == cal2.get(Calendar.WEEK_OF_YEAR))
   return true;
  }
  else if (1 == subYear && 11 == cal2.get(Calendar.MONTH)) {
    // 如果12月的最后一周横跨来年第一周的话则最后一周即算做来年的第一周
    if (cal1.get(Calendar.WEEK_OF_YEAR) == cal2.get(Calendar.WEEK_OF_YEAR))
   return true;
  }
  else if (-1 == subYear && 11 == cal1.get(Calendar.MONTH)) {
    if (cal1.get(Calendar.WEEK_OF_YEAR) == cal2.get(Calendar.WEEK_OF_YEAR))
   return true;
  }
  return false;
 }
 
 
 //产生周序列
 public static String  getSeqWeek(){
  Calendar c = Calendar.getInstance(Locale.CHINA);
  String week = Integer.toString(c.get(Calendar.WEEK_OF_YEAR));
  if(week.length()==1)week = "0" + week;
  String year = Integer.toString(c.get(Calendar.YEAR)); 
  return year+week;
 
 }
 
  //获得周一的日期
  public static String getMonday(Date date){
   Calendar c = Calendar.getInstance();
   c.setTime(date);
   c.set(Calendar.DAY_OF_WEEK,Calendar.MONDAY);
   return new SimpleDateFormat("yyyy-MM-dd").format(c.getTime());
  }
 
 
  //获得周五的日期
  public static String getFriday(Date date){
   Calendar c = Calendar.getInstance();
   c.setTime(date);
   c.set(Calendar.DAY_OF_WEEK,Calendar.FRIDAY);  
   return new SimpleDateFormat("yyyy-MM-dd").format(c.getTime());
  
  
  }
 
  public static void main(String[] args){

  }

}

posted @ 2007-11-01 15:03 chaochao 阅读(303) | 评论 (0)编辑 收藏
     摘要: 1. SQL server里的数据类型bigint和JAVA中的类型long对应。所以:id is bigint in sqlserver,so in java must use "getLong(id)" method.in sqlserver the index is begin with "1" instead of "0". 2. java.sql.SQLException: [Micr...  阅读全文
posted @ 2007-10-18 16:50 chaochao 阅读(504) | 评论 (0)编辑 收藏