我尝试使用servlet类中的request.getParameter()获取html输入类型“ date”的值,然后将其转换为JDBC Class中的java date,然后转换为sql date格式。
但存在此异常java.text.ParseException:无法解析 日期。
这是日期的HTML标记
输入type =“ date” name =“出生日期”
这是从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());
答案 0 :(得分:1)
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.util.Date
,java.sql.Date
,Calendar
,SimpleDateFormat
等。
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 8及更高版本中。这些类取代了麻烦的旧legacy日期时间类,例如java.util.Date
,Calendar
和SimpleDateFormat
。
目前位于Joda-Time的maintenance 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中添加内容提供了一个试验场。您可能会在这里找到一些有用的类,例如Interval
,YearWeek
,YearQuarter
和more。