我试图在servlet类中使用request.getParameter()获得html输入类型“ date”的值,然后在JDBC类中将其转换为java date,然后转换为sql date格式。


  但是存在此异常java.text.ParseException:无法解析
  日期。


这是日期的HTML标签


  输入type =“ date” name =“ BirthDate”


这是从HTML页面获取价值的servlet代码

String bDate = request.getParameter("BirthDate");


这是将其转换的JDBC类代码

String bbd = user.getBDate();
DateFormat df = new SimpleDateFormat("dd/MM/yyy");
java.util.Date bbDate = df.parse(bbd);;
java.sql.Date bDate = new java.sql.Date(bbDate.getTime());

最佳答案

tl; dr

myPreparedStatement.setObject(                       // As of JDBC 4.2, pass java.time objects to your database.
    … ,
    LocalDate                                        // Represent a date-only value, without time-of-day and without time zone.
    .parse(                                          // Convert text to a `LocalDate` object.
        "23/01/2018" ,
        DateTimeFormatter.ofPattern( "dd/MM/uuuu" )  // Specify formatting pattern to match user input.
    )                                                // Returns a `LocalDate` object.
)


java.time

仅使用java.time类。切勿使用java.util.Datejava.sql.DateCalendarSimpleDateFormat等。

String input = "23/01/2018" ;
DateTimeFormatter f = DateTimeFormatter.ofPattern( "dd/MM/uuuu" ) ;
LocalDate ld = LocalDate.parse( input , f ) ;


从JDBC 4.2开始,我们可以直接与数据库交换java.time对象。

myPreparedStatement.setObject( … , ld ) ;


恢复。

LocalDate ld = myResultSet.getObject( … , LocalDate.class ) ;




关于java.time

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

现在位于Joda-Time中的maintenance mode项目建议迁移到java.time类。

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

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

在哪里获取java.time类?


Java SE 8Java SE 9Java SE 10Java SE 11和更高版本-具有捆绑实现的标准Java API的一部分。


Java 9添加了一些次要功能和修复。

Java SE 6Java SE 7


大多数java.time功能都被反向移植到ThreeTen-Backport中的Java 6和7。

Android


更高版本的Android捆绑了java.time类的实现。
对于较早的Android(ThreeTenABP项目改编为ThreeTen-Backport(如上所述)。请参见How to use ThreeTenABP…



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

07-25 22:19
查看更多