将java getTime时间与表示日期的字符串进行比较

时间:2017-08-21 13:33:49

标签: java android

每次在ab sqlite数据库中执行3列(一天,一个月和一年)时,我都存储了特定方法的日期。

现在我想将其与用户使用该应用的行为日期进行比较。随着

Date currentTime = Calendar.getInstance().getTime()

我得到了这个日期,但是如何将它与我从数据库中获得的字符串进行比较?谢谢!

2 个答案:

答案 0 :(得分:1)

使用java.time

您的问题与许多其他问题重复。简而言之......

使用java.time类而不是麻烦的旧遗留日期时间类。对于Android,请使用ThreeTen-Backport和ThreeTenABP项目中的库。

获取今天的约会。

ZoneId z = ZoneId.of( "America/Montreal" ) )
LocalDate today = LocalDate.now( z );

获取部分日期。

int y = today.getYear() ;
int m = today.getMonthValue() ;
int d = today.getDayOfMonth() ;

查询数据库。

myPreparedStatement.setInt( 1 , y ) ;
myPreparedStatement.setInt( 2 , m ) ;
myPreparedStatement.setInt( 3 , d ) ;

正如其他人所建议的那样,您应该在数据库中使用日期时间类型来存储日期时间值,而不仅仅是片段的整数。

关于java.time

java.time框架内置于Java 8及更高版本中。这些类取代了麻烦的旧legacy日期时间类,例如java.util.DateCalendar和& SimpleDateFormat

现在位于Joda-Timemaintenance mode项目建议迁移到java.time类。

要了解详情,请参阅Oracle Tutorial。并搜索Stack Overflow以获取许多示例和解释。规范是JSR 310

从哪里获取java.time类?

ThreeTen-Extra项目使用其他类扩展java.time。该项目是未来可能添加到java.time的试验场。您可以在此处找到一些有用的课程,例如IntervalYearWeekYearQuartermore

答案 1 :(得分:0)

试试这个:

SimpleDateFormat formattedDate = new SimpleDateFormat("dd/MM/yyyy");  
String strDate= formattedDate.format(date);  

它将为您提供模板中显示的日期。现在只需以相同的方式(dd / MM / yyyy)从您的SQLite数据中构建一个String,您只需比较它们就像这篇文章中所示:https://stackoverflow.com/questions/513832/how-do-i-compare-strings-in-java