Resetting the time part of a timestamp in Java

后端 未结 10 1216
慢半拍i
慢半拍i 2020-12-04 23:56

In Java, given a timestamp, how to reset the time part alone to 00:00:00 so that the timestamp represents the midnight of that particular day ?

In T-SQL, this query

10条回答
  •  既然无缘
    2020-12-05 00:37

    You can go Date->Calendar->set->Date:

    Date date = new Date();                      // timestamp now
    Calendar cal = Calendar.getInstance();       // get calendar instance
    cal.setTime(date);                           // set cal to date
    cal.set(Calendar.HOUR_OF_DAY, 0);            // set hour to midnight
    cal.set(Calendar.MINUTE, 0);                 // set minute in hour
    cal.set(Calendar.SECOND, 0);                 // set second in minute
    cal.set(Calendar.MILLISECOND, 0);            // set millis in second
    Date zeroedDate = cal.getTime();             // actually computes the new Date
    

    I love Java dates.

    Note that if you're using actual java.sql.Timestamps, they have an extra nanos field. Calendar of course, knows nothing of nanos so will blindly ignore it and effectively drop it when creating the zeroedDate at the end, which you could then use to create a new Timetamp object.

    I should also note that Calendar is not thread-safe, so don't go thinking you can make that a static single cal instance called from multiple threads to avoid creating new Calendar instances.

提交回复
热议问题