我有一个要求,比如当我在我的数据库中的表中插入值时,我需要设置目标日期,它与插入日期相隔3个月。例如:如果我在2013年11月9日插入数据,我的目标日期将是2014年2月9日,2015年5月9日,依此类推。我也将这些目标日期存储在各自的列中。为此,我使用日历功能并将3个月添加到当前实例。现在,企业不希望我的目标日期在星期六或星期日到来。如果它来了,我需要添加所需的天数,以便它在工作日出现。
关于我们如何做到这一点的任何建议
答案 0 :(得分:2)
从你已经知道的开始。您知道可以使用Calendar
向/从中添加/减去值并生成结果值....
Calendar cal = Calendar.getInstance();
cal.clear();
cal.set(Calendar.DATE, 9);
cal.set(Calendar.MONTH, Calendar.NOVEMBER);
cal.set(Calendar.YEAR, 2013);
System.out.println("Start at " + cal.getTime());
cal.add(Calendar.MONTH, 3);
System.out.println("End at " + cal.getTime());
哪些输出......
Start at Sat Nov 09 00:00:00 EST 2013
End at Sun Feb 09 00:00:00 EST 2014
现在,你需要使用这个概念来推动这一天,直到它不是一个星期结束。您可以使用Calendar.DAY_OF_WEEK
获取“日期”名称,只需根据您的业务规则向Calendar.DATE
添加或减去一天,例如......
while (cal.get(Calendar.DAY_OF_WEEK) == Calendar.SATURDAY || cal.get(Calendar.DAY_OF_WEEK) == Calendar.SUNDAY) {
cal.add(Calendar.DATE, 1);
}
System.out.println("Should end at " + cal.getTime());
哪个(基于前面的例子),输出......
Should end at Mon Feb 10 00:00:00 EST 2014
仔细查看Calendar
了解更多详情
答案 1 :(得分:0)
现代方法使用由ThreeTen-Extra项目扩展的java.time类。
LocalDate
类表示没有时间且没有时区的仅限日期的值。
LocalDate start = LocalDate.of( 2013 , Month.NOVEMBER , 9 ) ;
退一天,然后使用TemporalAdjuster
中的org.threeten.extra.Temporals
实施,请求下一个工作日(非星期六/星期日)。
LocalDate startAgain =
start.minusDays( 1 )
.with( org.threeten.extra.Temporals.nextWorkingDay() ) ;
为下一个日期添加三个月。再次,退后一天,并要求下一个工作日。
LocalDate threeMonthsLaterWorkingDay =
startAgain.plusMonths( 3 )
.minusDays( 1 )
.with( org.threeten.extra.Temporals.nextWorkingDay() ) ;
java.time框架内置于Java 8及更高版本中。这些类取代了麻烦的旧legacy日期时间类,例如java.util.Date
,Calendar
和& SimpleDateFormat
现在位于Joda-Time的maintenance mode项目建议迁移到java.time类。
要了解详情,请参阅Oracle Tutorial。并搜索Stack Overflow以获取许多示例和解释。规范是JSR 310。
从哪里获取java.time类?
ThreeTen-Extra项目使用其他类扩展java.time。该项目是未来可能添加到java.time的试验场。您可以在此处找到一些有用的课程,例如Interval
,YearWeek
,YearQuarter
和more。