将字符串转换为“ YYYY”格式的java.sql.Date对象

时间:2018-11-19 10:07:00

标签: java date date-formatting java-date

我想创建一个格式为“ YYYY”的java.sql.Date对象。它应该只有一年。我做了很多研究,但找不到解决方法。

2 个答案:

答案 0 :(得分:1)

您需要创建一个java.util.Date,然后使用包含java.sql.Date的构造函数将其转换为long

示例:

String year = "2018";

DateFormat format = new SimpleDateFormat("yyyy");
java.util.Date utilDate = format.parse(year);
java.sql.Date sqlDate = new java.sql.Date(utilDate.getTime());

但是,这不是“只有一年”。 Java中的日期始终具有时间成分,因此这是不可能的-在我的示例中,日期将为“ 1 Jan 2018 00:00:00 GMT”。这是否足够接近您想要的内容,或者您​​可以完善您的问题?

此外,java.sql.Date扩展了java.util.Date,因此理想情况下,应尽可能使用前者来满足Liskov替换原理。

答案 1 :(得分:1)

tl; dr

永远不要使用糟糕的java.sql.Date类,该类的设计有多个缺陷。

使用java.time.Year对象或整数。

myPreparedStatement.setObject( … , Year.of( 2018 ) ) ;

…或者在代码的其他部分使用Year时:

myPreparedStatement.setInt( … , Year.of( 2018 ).getValue() ) ;

java.time

现代的解决方案使用了几年前的 java.time 类,该类取代了SimpleDateFormatjava.util.Datejava.sql.Date和等等。

Year类巧妙地表示年份值。在代码中使用此类可为您提供类型安全性,并使代码更具自记录性。

解析字符串输入。

Year y = Year.parse( "2018" ) ;

解析整数输入。

Year y = Year.of( 2018 ) ;  // Integer literal.

JDBC

从JDBC 4.2开始,我们可以直接交换 java.time 类型。

交换Year对象

我不知道MySQL中是否包含Year类和YEAR数据类型。但是试一试。如果不是,请向JDBC驱动程序供应商提出功能请求以扩展支持。鉴于MySQL具有明确的YEAR类型,这似乎是一个合理的期望。

myPreparedStatement.setObject( … , y ) ;

检索。

Year y = myResultSet.getObject( … , Year.class ) ;

交换整数

如果您的JDBC驱动程序不能直接使用java.time.Year,请使用整数。

myPreparedStatement.setInt( … , y.getValue() ) ;  // Pass year as an integer number.

检索。

Year y = Year.of( myResultSet.getInt( … ) ) ;  // Retrieve integer, convert to `Year` object.

关于 java.time

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

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

要了解更多信息,请参见Oracle Tutorial。并在Stack Overflow中搜索许多示例和说明。规格为JSR 310

您可以直接与数据库交换 java.time 对象。使用符合JDBC driver或更高版本的JDBC 4.2。不需要字符串,不需要java.sql.*类。

在哪里获取java.time类?

ThreeTen-Extra项目使用其他类扩展了java.time。该项目为将来可能在java.time中添加内容提供了一个试验场。您可能会在这里找到一些有用的类,例如IntervalYearWeekYearQuartermore