结果集的java日期相关方法不起作用
我正在使用jdk-1.6, os-Redhat5, 司机-12级。jar(jar和jdk库) 数据库甲骨文10i
代码:-
public Timestamp getCurrentTimeStamp(Connection connection) throws SQLException {
Timestamp timeStamp = null;
try {
PreparedStatement ps = connection.prepareStatement(" SELECT CURRENT_TIMESTAMP FROM DUAL");
ResultSet rs = ps.executeQuery();
if (rs.next()) {
timeStamp = rs.getTimestamp("CURRENT_TIMESTAMP");
}
} catch(Exception e){}
return timeStamp;
}
在某些系统中,它工作正常,但在服务器上,它只抛出以下异常
java.sql.SQLException: Invalid column type
at oracle.jdbc.dbaccess.DBError.
throwSqlException(DBError.java:189)
at oracle.jdbc.dbaccess.DBError.throwSqlException(DBError.java:231)
at oracle.jdbc.dbaccess.DBError.throwSqlException(DBError.java:294)
at oracle.jdbc.driver.OracleStatement.getTimestampValue(OracleStatement.java:4627)
at oracle.jdbc.driver.OracleResultSetImpl.getTimestamp(OracleResultSetImpl.java:409)
at oracle.jdbc.driver.OracleResultSet.getTimestamp(OracleResultSet.java:1649)
at org.apache.tomcat.dbcp.dbcp.DelegatingResultSet.getTimestamp(DelegatingResultSet.java:262)
at myutils.FoursplUtils.getCurrentTimeStamp(FoursplUtils.java:131)
at NewServlet.processRequest(NewServlet.java:44)
at NewServlet.doGet(NewServlet.java:74)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:617)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.netbeans.modules.web.monitor.server.MonitorFilter.doFilter(MonitorFilter.java:390)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:293)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:849)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:583)
at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:454)
at java.lang.Thread.run(Thread.java:619)
只有resultset的时间相关函数不起作用。。。。。。。。(resultset.getTimestamp(),resultset。getDate())。 但是结果集。getString()工作正常
在java论坛中,我得到了答案,这是因为JRE时区设置与oracle return时区设置不同。。。 这是正确的还是错误的。。。。。 或者我该如何解决这个问题。。。。。。。。。。。。 请帮帮我
# 1 楼答案
如果时间戳被表示为时间戳,也就是1970年1月1日之后的毫秒数,那么你也许可以通过
getLong(..)
得到它。在这种情况下,即使是Long.parseLong(getString())
也可以如果数据库返回的字符串实际上是格式化的日期字符串,那么请检查格式并使用
SimpleDateFormat
对其进行分析我同意这有点“黑客”,所以首先尝试升级JDBC驱动程序