<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    keep moving!

    We must not cease from exploration. And the end of all our exploring will be to arrive where we began and to know the place for the first time.
    隨筆 - 37, 文章 - 2, 評論 - 3, 引用 - 0
    數據加載中……

    Java Date 錦囊

    相關文章:
    java中關于時間日期操作的常用函數
    如何確定一個月的某一周是從幾月幾號到幾號

    更多相關推薦 1.計算某一月份的最大天數

    Calendar time=Calendar.getInstance();
    time.clear();
    time.set(Calendar.YEAR,year); //year 為 int
    time.set(Calendar.MONTH,i-1);//注意,Calendar對象默認一月為0
    int day=time.getActualMaximum(Calendar.DAY_OF_MONTH);//本月份的天數
    注:在使用set方法之前,必須先clear一下,否則很多信息會繼承自系統當前時間

    2.Calendar和Date的轉化

    (1) Calendar轉化為Date
    Calendar cal=Calendar.getInstance();
    Date date=cal.getTime();

    (2) Date轉化為Calendar
    Date date=new Date();
    Calendar cal=Calendar.getInstance();
    cal.setTime(date);

    3.格式化輸出日期時間 (這個用的比較多)

    Date date=new Date();
    SimpleDateFormat df=new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
    String time=df.format(date);
    System.out.println(time);

    4.計算一年中的第幾星期

    (1)計算某一天是一年中的第幾星期
    Calendar cal=Calendar.getInstance();
    cal.set(Calendar.YEAR, 2006);
    cal.set(Calendar.MONTH, 8);
    cal.set(Calendar.DAY_OF_MONTH, 3);
    int weekno=cal.get(Calendar.WEEK_OF_YEAR);

    (2)計算一年中的第幾星期是幾號
    SimpleDateFormat df=new SimpleDateFormat("yyyy-MM-dd");
    Calendar cal=Calendar.getInstance();
    cal.set(Calendar.YEAR, 2006);
    cal.set(Calendar.WEEK_OF_YEAR, 1);
    cal.set(Calendar.DAY_OF_WEEK, Calendar.MONDAY);
    System.out.println(df.format(cal.getTime()));
    輸出:
    2006-01-02

    5.add()和roll()的用法(不太常用)

    (1)add()方法
    SimpleDateFormat df=new SimpleDateFormat("yyyy-MM-dd");
    Calendar cal=Calendar.getInstance();
    cal.set(Calendar.YEAR, 2006);
    cal.set(Calendar.MONTH, 8);
    cal.set(Calendar.DAY_OF_MONTH, 3);
    cal.add(Calendar.DATE, -4);
    Date date=cal.getTime();
    System.out.println(df.format(date));
    cal.add(Calendar.DATE, 4);
    date=cal.getTime();
    System.out.println(df.format(date));
    輸出:
    2006-08-30
    2006-09-03
    (2)roll方法
    cal.set(Calendar.YEAR, 2006);
    cal.set(Calendar.MONTH, 8);
    cal.set(Calendar.DAY_OF_MONTH, 3);
    cal.roll(Calendar.DATE, -4);
    date=cal.getTime();
    System.out.println(df.format(date));
    cal.roll(Calendar.DATE, 4);
    date=cal.getTime();
    System.out.println(df.format(date));
    輸出:
    2006-09-29
    2006-09-03
    可見,roll()方法在本月內循環,一般使用add()方法;

    6.計算兩個任意時間中間的間隔天數(這個比較常用)
    (1)傳進Calendar對象
    public int getIntervalDays(Calendar startday,Calendar endday)...{
    if(startday.after(endday))...{
    Calendar cal=startday;
    startday=endday;
    endday=cal;
    }
    long sl=startday.getTimeInMillis();
    long el=endday.getTimeInMillis();

    long ei=el-sl;
    return (int)(ei/(1000*60*60*24));
    }
    (2)傳進Date對象

    public int getIntervalDays(Date startday,Date endday)...{
    if(startday.after(endday))...{
    Date cal=startday;
    startday=endday;
    endday=cal;
    }
    long sl=startday.getTime();
    long el=endday.getTime();
    long ei=el-sl;
    return (int)(ei/(1000*60*60*24));
    }
    (3)改進精確計算相隔天數的方法
    public int getDaysBetween (Calendar d1, Calendar d2) ...{
    if (d1.after(d2)) ...{
    java.util.Calendar swap = d1;
    d1 = d2;
    d2 = swap;
    }
    int days = d2.get(Calendar.DAY_OF_YEAR) - d1.get(Calendar.DAY_OF_YEAR);
    int y2 = d2.get(Calendar.YEAR);
    if (d1.get(Calendar.YEAR) != y2) ...{
    d1 = (Calendar) d1.clone();
    do ...{
    days += d1.getActualMaximum(Calendar.DAY_OF_YEAR);//得到當年的實際天數
    d1.add(Calendar.YEAR, 1);
    } while (d1.get(Calendar.YEAR) != y2);
    }
    return days;
    }
    注意:通過上面的方法可以衍生出求任何時間,如要查出郵箱三周之內收到的郵件(得到當前系統時間-再得到三周前時間)用收件的時間去匹配 最好裝化成 long去比較
    如:1年前日期(注意毫秒的轉換)
    java.util.Date myDate=new java.util.Date();
    long myTime=(myDate.getTime()/1000)-60*60*24*365;
    myDate.setTime(myTime*1000);
    String mDate=formatter.format(myDate);

    7. String 和 Date ,Long 之間相互轉換 (最常用)

    字符串轉化成時間類型(字符串可以是任意類型,只要和SimpleDateFormat中的格式一致即可)
    通常我們取時間跨度的時候,會substring出具體時間--long-比較

    java.text.SimpleDateFormat sdf = new java.text.SimpleDateFormat("M/dd/yyyy hh:mm:ss a",java.util.Locale.US);
    java.util.Date d = sdf.parse("5/13/2003 10:31:37 AM");
    long dvalue=d.getTime();
    SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
    String mDateTime1=formatter.format(d);

    8. 通過時間求時間

    年月周求日期
    SimpleDateFormat formatter2 = new SimpleDateFormat("yyyy-MM F E");
    java.util.Date date2= formatter2.parse("2003-05 5 星期五");
    SimpleDateFormat formatter3 = new SimpleDateFormat("yyyy-MM-dd");
    String mydate2=formatter3.format(date2);

    求是星期幾
    mydate= myFormatter.parse("2001-1-1");
    SimpleDateFormat formatter4 = new SimpleDateFormat("E");
    String mydate3=formatter4.format(mydate);

    9. java 和 具體的數據庫結合

    在開發web應用中,針對不同的數據庫日期類型,我們需要在我們的程序中對日期類型做各種不同的轉換。若對應數據庫數據是oracle的Date類型,即只需要年月日的,可以選擇使用java.sql.Date類型,若對應的是MSsqlserver 數據庫的DateTime類型,即需要年月日時分秒的,選擇java.sql.Timestamp類型
    你可以使用dateFormat定義時間日期的格式,轉一個字符串即可

    class Datetest{
    *method 將字符串類型的日期轉換為一個timestamp(時間戳記java.sql.Timestamp)
    *@param dateString 需要轉換為timestamp的字符串
    *@return dataTime timestamp

    public final static java.sql.Timestamp string2Time(String dateString)
    throws java.text.ParseException {
    DateFormat dateFormat;
    dateFormat = new SimpleDateFormat("yyyy-MM-dd kk:mm:ss.SSS", Locale.ENGLISH);//設定格式
    //dateFormat = new SimpleDateFormat("yyyy-MM-dd kk:mm:ss", Locale.ENGLISH);
    dateFormat.setLenient(false);
    java.util.Date timeDate = dateFormat.parse(dateString);//util類型
    java.sql.Timestamp dateTime = new java.sql.Timestamp(timeDate.getTime());//Timestamp類型,timeDate.getTime()返回一個long型
    return dateTime;
    }

    *method 將字符串類型的日期轉換為一個Date(java.sql.Date)
    *@param dateString 需要轉換為Date的字符串
    *@return dataTime Date

    public final static java.sql.Date string2Date(String dateString)
    throws java.lang.Exception {
    DateFormat dateFormat;
    dateFormat = new SimpleDateFormat("yyyy-MM-dd", Locale.ENGLISH);
    dateFormat.setLenient(false);
    java.util.Date timeDate = dateFormat.parse(dateString);//util類型
    java.sql.Date dateTime = new java.sql.Date(timeDate.getTime());//sql類型
    return dateTime;
    }

    public static void main(String[] args){
    Date da = new Date();
    注意:這個地方da.getTime()得到的是一個long型的值
    System.out.println(da.getTime());

    由日期date轉換為timestamp

    第一種方法:使用new Timestamp(long)
    Timestamp t = new Timestamp(new Date().getTime());
    System.out.println(t);

    第二種方法:使用Timestamp(int year,int month,int date,int hour,int minute,int second,int nano)
    Timestamp tt = new Timestamp(Calendar.getInstance().get(
    Calendar.YEAR) - 1900, Calendar.getInstance().get(
    Calendar.MONTH), Calendar.getInstance().get(
    Calendar.DATE), Calendar.getInstance().get(
    Calendar.HOUR), Calendar.getInstance().get(
    Calendar.MINUTE), Calendar.getInstance().get(
    Calendar.SECOND), 0);
    System.out.println(tt);

    try {
    String sToDate = "2005-8-18";//用于轉換成java.sql.Date的字符串
    String sToTimestamp = "2005-8-18 14:21:12.123";//用于轉換成java.sql.Timestamp的字符串
    Date date1 = string2Date(sToDate);
    Timestamp date2 = string2Time(sToTimestamp);
    System.out.println("Date:"+date1.toString());//結果顯示
    System.out.println("Timestamp:"+date2.toString());//結果顯示
    }catch(Exception e) {
    e.printStackTrace();
    }
    }
    }

    posted on 2008-09-07 02:21 大石頭 閱讀(235) 評論(0)  編輯  收藏 所屬分類: 基礎

    主站蜘蛛池模板: 国产精品亚洲美女久久久| 久久受www免费人成_看片中文| 日韩激情淫片免费看| 亚洲日本成本人观看| 免费看少妇作爱视频| 亚洲人成网站色7799| 国产在线不卡免费播放| 西西人体大胆免费视频| 亚洲男人的天堂在线va拉文| a高清免费毛片久久| 亚洲永久精品ww47| 无码日韩精品一区二区免费暖暖| 亚洲国产一区二区a毛片| 永久在线免费观看| 亚洲自国产拍揄拍| 日本免费福利视频| eeuss影院免费直达入口| 亚洲高清专区日韩精品| 69av免费视频| 亚洲第一街区偷拍街拍| 亚洲国产成人精品久久久国产成人一区二区三区综 | 国产在线国偷精品产拍免费| 亚洲一区二区三区播放在线| 在线精品免费视频| 国产精品免费一区二区三区| 亚洲国产精品久久久久| 成人免费一级毛片在线播放视频| 亚洲av中文无码字幕色不卡| 亚洲国产中文v高清在线观看| 97无码人妻福利免费公开在线视频| 亚洲自偷自拍另类12p| 成人免费看片又大又黄| 一级做a爰片久久毛片免费陪 | 亚洲av永久无码精品网站| 最近中文字幕免费mv在线视频| 国产亚洲国产bv网站在线| 亚洲成a人一区二区三区| 美女视频黄a视频全免费网站色窝 美女被cao网站免费看在线看 | 久久免费高清视频| 亚洲人成欧美中文字幕| 亚洲一区二区三区无码中文字幕|