Как я могу наилучшим образом преобразовать java.util.Date
в Java 8 java.time.YearMonth
?Как преобразовать java.util.Date в Java8 java.time.YearMonth
К сожалению следующее бросает DateTimeException
:
YearMonth yearMonth = YearMonth.from(date.toInstant());
приводит:
java.time.DateTimeException: Unable to obtain YearMonth from TemporalAccessor: 2015-01-08T14:28:39.183Z of type java.time.Instant
at java.time.YearMonth.from(YearMonth.java:264)
...
мне нужна эта функция, так как я хочу, чтобы хранить YearMonth
значений в базе данных с помощью JPA. В настоящее время JPA не поддерживает YearMonth
«S, поэтому я придумал следующий YearMonthConverter (импорт опущена):
// TODO (future): delete when next version of JPA (i.e. Java 9?) supports YearMonth. See https://java.net/jira/browse/JPA_SPEC-63
@Converter(autoApply = true)
public class YearMonthConverter implements AttributeConverter<YearMonth, Date> {
@Override
public Date convertToDatabaseColumn(YearMonth attribute) {
// uses default zone since in the end only dates are needed
return attribute == null ? null : Date.from(attribute.atDay(1).atStartOfDay(ZoneId.systemDefault()).toInstant());
}
@Override
public YearMonth convertToEntityAttribute(Date dbData) {
// TODO: check if Date -> YearMonth can't be done in a better way
if (dbData == null) return null;
Calendar calendar = Calendar.getInstance();
calendar.setTime(dbData);
return YearMonth.of(calendar.get(Calendar.YEAR), calendar.get(Calendar.MONTH) + 1);
}
}
не лучший (уборщик, короче) раствор (в обоих направлениях)?
Лично я хотел бы избежать отображение в 'java.util.Date 'потому что a) это не' java.sql. * '-type, b) включает неявный часовой пояс (плохая производительность и нечеткое использование системного часового пояса), c) SQL не определяет такой тип для года. Лучше сопоставить «YearMonth» с целым числом с помощью [PROLEPTIC_MONTH] (http://docs.oracle.com/javase/8/docs/api/java/time/temporal/ChronoField.html#PROLEPTIC_MONTH) –
@MenoHochschild: Это хорошая идея - только оговорка заключается в том, что она не читается при просмотре самой базы данных. Нет проблем в моем случае ... – Sebastian
Ну, просто целое число не читается для прямого просмотра содержимого db, но имейте в виду, что отображение в juDate может изменить визуализированную дату и месяц (как видит администратор db) из-за часового пояса конверсий и настроек db/server. –