Sunday, March 30, 2014

Java 8 Date Time API Tutorial : LocalDateTime

This blogpost is a part of tutorial series on Date Time API introduced in Java 8. In this blogpost I will go over some of the methods available in LocalDateTime class.
LocalDateTime is an immutable, thread safe object which represents date-time without a time-zone in the ISO-8601 calendar system, such as 2014-03-30T02:51:21. It is normally represented in year-month-day-hour-minute-second and provides accuracy up to the range of nanoseconds.

For month, the valid value range is 1 - 28/31
For hours, the valid value range is 0 – 23.
The valid values for minutes and seconds are in the range 0 – 59.
For nano seconds the valid value range is 0 – 999999999.

The LocalDateTime object can be created in a number of ways listed below.


LocalDateTime dateTime = LocalDateTime.now();//returns the system date time in the default timezone.
System.out.println("dateTime from the system is:"+dateTime);

//creates a date time with the values provided as parameters in the sequence year, month, day of the month, hour of the day, minute of the hour. The second and nano second are set to 0. 
LocalDateTime ldtm = LocalDateTime.of(2014, 3, 30, 12, 30);
System.out.println("dateTime created by passing in year, month,day, hour, minute is:"+ldtm.toString());

//creates a date time with the values provided as parameters in the sequence year, month, day of the month, hour of the day, minute of the hour, seconds of the minute. The nano second is set to 0.
LocalDateTime ldts = LocalDateTime.of(2014, 3, 30, 12, 30,23);
System.out.println("dateTime created by passing in year, month,day, hour, minute, seconds is :"+ldts.toString());

//creates a date time with the values provided as parameters in the sequence year, month, day of the month, hour of the day, minute of the hour, seconds of the minute and nano second of the second.
LocalDateTime ldtns = LocalDateTime.of(2014, 3, 30, 12, 30,23,12000);
System.out.println("dateTime created by passing in year, month,day, hour, minute, seconds, nano seconds is :"+ldtns.toString());

//creates a date time with the values provided as parameters in the sequence year, month value from the Month enum, day of the month, hour of the day, minute of the hour. The second and nano second are set to 0.
LocalDateTime ldtem = LocalDateTime.of(2013, Month.APRIL, 1, 12, 30);
System.out.println("The date time object created by passing in year, month from enum, day, hour , minute is : "+ldtem.toString());

//creates a date time with the values provided as parameters in the sequence year, month value from the Month enum, day of the month, hour of the day, minute of the hour, seconds of the minute. The nano second is set to 0.
LocalDateTime ldtes = LocalDateTime.of(2013, Month.APRIL, 1, 12, 30,42);
System.out.println("The date time object created by passing in year, month from enum, day, hour , minute,second is : "+ldtes.toString());

//creates a date time with the values provided as parameters in the sequence year, month value from the Month enum, day of the month, hour of the day, minute of the hour, seconds of the minute and nano seconds of the seconds.
LocalDateTime ldtens = LocalDateTime.of(2013, Month.APRIL, 1, 12, 30,42,12000);
System.out.println("The date time object created by passing in year, month from enum, day, hour , minute,seconds, ns is : "+ldtens.toString());
There are several methods to get the values of the fields like Month, Year, day of week, day of the month, seconds, minutes, nano seconds.
             

int dayOfMonth = dateTime.getDayOfMonth();//returns the day of the month.
System.out.println("day Of Month is :"+dayOfMonth);
DayOfWeek dow = dateTime.getDayOfWeek();//returns DayOfWeek enum.
System.out.println("dow:"+dow);
int dayOfYear = dateTime.getDayOfYear();//returns the day of the year.
System.out.println("day Of Year is :"+dayOfYear);
int hour = dateTime.getHour();//returns hour of the day.
System.out.println("hour:"+hour);
int monthValue = dateTime.getMonthValue();//returns the number of the month in the year.
System.out.println("month of the date in number is:"+monthValue);
Month month = dateTime.getMonth();// returns the month enum for the month of the year.
System.out.println("month of the date is :"+month);
int sec = dateTime.getSecond();// returns seconds field value for the date time.
System.out.println("Seconds of the date time is:"+sec);
int nano = dateTime.getNano();();// returns nano seconds field value for the date time.
System.out.println("nano seconds of the date time is:"+nano);
int year = dateTime.getYear();();// returns year field value for the date time.
System.out.println("year of the date is :"+year);

There are several minusXXX methods which can subtract values for the fields from the date.
//creates a new date time copy after subtracting 10 days from the date time.
LocalDateTime ldtmd = dateTime.minusDays(10);
 System.out.println("date time after subtracting days is : "+ldtmd.toString());
//creates a new date time copy after subtracting 10 hours from the date time.
LocalDateTime ldtmh = dateTime.minusHours(10);
System.out.println("date time after subtracting hours is : "+ldtmh.toString());
//creates a new date time copy after subtracting 21 minutes from the date time.
LocalDateTime ldtmm = dateTime.minusMinutes(21);
System.out.println("date time after subtracting minutes is : "+ldtmm.toString());
//creates a new date time copy after subtracting 2 months from the date time.
LocalDateTime ldtmmm = dateTime.minusMonths(2);
System.out.println("date time after subtracting months is : "+ldtmmm.toString());
//creates a new date time copy after subtracting 3 years from the date time.
LocalDateTime ldtmy = dateTime.minusYears(3);
System.out.println("date time after subtracting years is : "+ldtmy.toString());
//creates a new date time copy after subtracting 32 weeks from the date time.
LocalDateTime ldtmw = dateTime.minusWeeks(32);
System.out.println("date time after subtracting weeks is : "+ldtmw.toString());
//creates a new date time copy after subtracting 1200 seconds from the date time.
LocalDateTime ldtms = dateTime.minusSeconds(1200);
System.out.println("date time after subtracting secs is : "+ldtms.toString());
//creates a new date time copy after subtracting 12000 nano seconds from the date time.
LocalDateTime ldtmn = dateTime.minusNanos(12000);
System.out.println("date time after subtracting nanos is : "+ldtmn.toString());

Similarly there are plusXXX methods which can add the values to the fields of the date time can create LocalDateTime object.

//creates a new date time copy after adding 10 days to the date time. 
LocalDateTime ldtpd = dateTime.plusDays(10);
System.out.println("date time after adding days is : "+ldtpd.toString());
//creates a new date time copy after adding 100 hours to the date time. 
LocalDateTime ldtph = dateTime.plusHours(100);
System.out.println("date time after adding hours is : "+ldtph.toString());
//creates a new date time copy after adding 190 minutes to the date time. 
LocalDateTime ldtpmm = dateTime.plusMinutes(190);
System.out.println("date time after adding minutes is : "+ldtpmm.toString());
//creates a new date time copy after adding 32 months to the date time. 
LocalDateTime ldtpdm = dateTime.plusMonths(32);
System.out.println("date time after adding months is : "+ldtpdm.toString());
//creates a new date time copy after adding 120000 nano seconds to the date time. 
LocalDateTime ldtpn = dateTime.plusNanos(120000);
System.out.println("date time after adding nanos is : "+ldtpn.toString());
//creates a new date time copy after adding 1200 seconds to the date time. 
LocalDateTime ldtps = dateTime.plusSeconds(1200);
System.out.println("date time after adding seconds is : "+ldtps.toString());
//creates a new date time copy after adding 24 weeks to the date time. 
LocalDateTime ldtpw = dateTime.plusWeeks(24);
System.out.println("date time after adding weeks is : "+ldtpw.toString());
//creates a new date time copy after adding 3 years to the date time. 
LocalDateTime ldtpy = dateTime.plusYears(3);
System.out.println("date time after adding years is : "+ldtpy.toString());
             
There are several withXXX methods which can set the value to the particular field.
LocalDateTime ldtmddm = dateTime.withDayOfMonth(10); // sets the day of the month to 10.
System.out.println("date time after adding modifying day of the month is : "+ldtmddm.toString());
LocalDateTime ldtmddy = dateTime.withDayOfYear(12);//sets the day of year to 12.
System.out.println("date time after adding modifying day of the year is : "+ldtmddy.toString());
LocalDateTime ldtmdh = dateTime.withHour(12);//sets the hour of the day to 12. The other date time fields are not modified.
System.out.println("date time after adding modifying hour is : "+ldtmdh.toString());
LocalDateTime ldtmdmm = dateTime.withMinute(12);//sets the minute of the hour to 12. The other date time fields are not modified.
System.out.println("date time after adding modifying minutes is : "+ldtmdmm.toString());
LocalDateTime ldtmdm = dateTime.withMonth(4);//sets the month to 4. The other date time fields are not modified.
System.out.println("date time after adding modifying month is : "+ldtmdm.toString());
LocalDateTime ldtmdy = dateTime.withYear(2011);//sets the year to 2012. The other date time fields are not modified.
System.out.println("date time after adding modifying year  is : "+ldtmdy.toString());
LocalDateTime ldtmds = dateTime.withSecond(12);//sets the seconds of the minute to 12. The other date time fields are not modified.
System.out.println("date time after adding modifying seconds is : "+ldtmds.toString());
LocalDateTime ldtmdn = dateTime.withNano(120000);//sets the nano seconds of seconds to 120000. The other date time fields are not modified.
System.out.println("date time after adding modifying nanos is : "+ldtmdn.toString());


If you want to retrieve only the date or time from this date time, then the following methods can do that.

LocalDate ld = dateTime.toLocalDate();//gets the date value(LocalDate) from the date time. A LocalDate with same year, month and day as this LocalDateTime object will be returned.
System.out.println("The date field from the date time object is : "+ld.toString());
LocalTime lt = dateTime.toLocalTime();// gets the time value(LocalTime) from the date time. returns a LocalTime with the same hour, minute, second and nanosecond as this date-time.
System.out.println("The time field from the date time object is : "+lt.toString());
Conclusion: LocalDateTime has several options to manipulate the date and time, some of which are described below. 

Java 8 Date Time API Tutorial : LocalTime

This blogpost is a part of tutorial series on Date Time API introduced in Java 8. In this blogpost, I will go over some of the methods available in LocalTime class.

LocalTime is an immutable, thread-safe date-time object that represents time normally viewed as hour-minute-second. This can provide time with precision up to nano secs. And also this class deals with time only.

There are several ways to create a LocalTime object, some of them indicated below.


LocalTime lt = LocalTime.now(); // retrieves the time from the local system in 
// the default time zone.
System.out.println("The time now is :"+lt.toString());
LocalTime lt2mins = LocalTime.of(4, 34);// creates a time with the provided 
// hours and minutes values.
System.out.println("The time after setting hours and minutes is :"+lt2mins.toString());
LocalTime lt2secs = LocalTime.of(4, 34, 23); );// creates a time with the 
// provided hours, minutes and secs values.
System.out.println("The time after setting hours minutes and secs is :"+lt2secs.toString());
LocalTime lt2ns = LocalTime.of(4, 32, 34, 120); );// creates a time with 
// the provided hours, minutes, secs and nano seconds values.
System.out.println("The time after setting hours, minutes,secs and nano secs is :"+lt2ns.toString());

There are a couple of other methods available to create LocalTime object. LocalTime can be created by either passing in the number of nanoseconds or seconds.
             

LocalTime ltnd = LocalTime.ofNanoOfDay(120000);//Creates time equal to 120000 nano seconds.
System.out.println("The time after setting nanos of the day  is :"+ltnd.toString());
LocalTime ltsd = LocalTime.ofSecondOfDay(32100);//Creates time equal to 32100 seconds
System.out.println("The time after setting seconds of the day  is :"+ltsd.toString());
             
There are several getXXX methods which can return the field values for hours, minutes, seconds and nanoseconds.

 
int hour = lt.getHour();//returns the hour value from the time.
System.out.println("The hours of the time  is :"+hour);
int mins = lt.getMinute();//returns the minute value from the time.
System.out.println("The minutes of the time  is :"+mins);
int nanos = lt.getNano();//returns the nano seconds value from the time.
System.out.println("The nanos of the time  is :"+nanos);
int secs = lt.getSecond();//returns the seconds value from the time.
System.out.println("The secs of the time  is :"+secs);
The below methods convert the time object into secs or nanoseconds

 
long nanoOfDay = lt.toNanoOfDay();//converts the time into the number of nano seconds.
System.out.println("The nanos of the day  is :"+nanoOfDay);
int secOfDay = lt.toSecondOfDay();//converts time into seconds.
System.out.println("The secs of the day  is :"+secOfDay);
      
There are several plusXXX methods which can add hours/minutes/seconds/nanoseconds to the time.
             

LocalTime ltph = lt.plusHours(10);//Adds 10 hours to the existing time.
System.out.println("The time after adding hours  is :"+ltph.toString());
LocalTime ltpm = lt.plusMinutes(20);//Adds 20 minutes to the existing time.
System.out.println("The time after adding minutes  is :"+ltpm.toString());
LocalTime ltpn = lt.plusNanos(12000);//Adds 12000 nano seconds to the existing time object.
System.out.println("The time after adding nanos  is :"+ltpn.toString());
LocalTime ltps = lt.plusSeconds(120);//Adds 120 seconds to the time object.
System.out.println("The time after adding secs  is :"+ltps.toString());
             

Similar to plusXXX methods there are several minusXXX methods which can subtract hours/minutes/seconds/nanoseconds from the time.


LocalTime ltmh = lt.minusHours(21);//Subtract 21 hours to existing time.
System.out.println("The time after subtracting hours  is :"+ltmh.toString());
LocalTime ltmm = lt.minusMinutes(123); //Subtract 123 minutes to existing time.
System.out.println("The time after subtracting minutes  is :"+ltmm.toString());
LocalTime ltmn = lt.minusNanos(120000); //Subtract 120000 nanoseconds to existing time.
System.out.println("The time after subtracting nanos  is :"+ltmn.toString());
LocalTime ltms = lt.minusSeconds(120); //Subtract 120 seconds to existing time.
System.out.println("The time after subtracting secs  is :"+ltms.toString());
There are some methods to set particular values to the fields.


LocalTime lth = lt.withHour(4); //sets the hour of the day to 4. The values should be in the range 0-23.
System.out.println("The time after setting hours of the day  is :"+lth.toString());
LocalTime ltm = lt.withMinute(12); //sets the minute of the hours to 12. The valid values 0 - 59
System.out.println("The time after setting minutes of the hour  is :"+ltm.toString());
LocalTime ltn = lt.withNano(12000);//sets nano seconds to seconds. valid values 0 - 999999999
System.out.println("The time after setting nanos of the second  is :"+ltn.toString());
LocalTime lts = lt.withSecond(12); //sets the seconds of the minute to 12. The valid values 0 - 59
System.out.println("The time after setting seconds of the minute  is :"+lts.toString());         
I did not cover all the methods in the LocalTime class, but this should be a good starting point to understand the uses of LocalTime class.