我尝试从oracle db获取一些数据,将此数据放在json中并在其他地方使用它,但我在转换timestamptz时遇到问题。 Oracle给我时间戳字符串格式的时区,例如" 23.10.14 18:34:16,000000 ASIA / NOVOSIBIRSK"。这是我的一些代码。
public void loadFromDb(ResultSet resultSet, Connection oc) throws SQLException {
ResultSetMetaData metaData = resultSet.getMetaData();
int columnCount = metaData.getColumnCount();
for (int i = 1; i <= columnCount; i++) {
Object obj = resultSet.getObject(i);
if (obj == null)
continue;
if (obj instanceof TIMESTAMPTZ) {
TIMESTAMPTZ ts = (TIMESTAMPTZ) obj;
if (oc != null) {
super.setValue(metaData.getColumnName(i), ts.stringValue(oc));
} else {
super.setValue(metaData.getColumnName(i), ts.stringValue());
}
}
}
我得到了这个例外
java.sql.SQLException: Conversion to String failed
at oracle.sql.Datum.stringValue(Datum.java:181)
顺便说一下,早些时候我的数字格式是时区,例如&#39; XX:XX&#39;而且这段代码也行不通,但是现在就这样做了super.setValue(metaData.getColumnName(i), ts.stringValue(null))
这样的方法就会产生nullpointerexception。
请帮助我,因为我尝试了在javadocs中找到的所有内容。
答案 0 :(得分:0)
TIMESTAMP
不是字符串,反之亦然。您需要使用TO_CHAR
和所需格式将其转换为字符串。
SQL> SELECT SYSTIMESTAMP
2 FROM dual
3 /
SYSTIMESTAMP
---------------------------------------------------------------------------
24-OCT-14 11.14.55.116000 AM +05:30
SQL>
SQL> SELECT TO_CHAR(systimestamp, 'DD-MON-YYYY HH24:MI:SS.FF TZH:TZM') tm
2 FROM dual
3 /
TM
-------------------------------------
24-OCT-2014 11:14:55.163000 +05:30
SQL> SELECT to_timestamp_tz('24-OCT-2014 11:07:40.348000 +05:30','DD-MON-YYYY HH24:MI:SS.FF TZH:TZM') tm
2 FROM dual
3 /
TM
---------------------------------------------------------------------------
24-OCT-14 11.07.40.348000000 AM +05:30
SQL> SELECT TO_TIMESTAMP('24-OCT-2014', 'DD-MON-YYYY')
2 FROM dual
3 /
TO_TIMESTAMP('24-OCT-2014','DD-MON-YYYY')
---------------------------------------------------------------------------
24-OCT-14 12.00.00.000000000 AM
让我们验证。
SQL> set serveroutput on;
SQL> DECLARE
2 tm_stamp TIMESTAMP;
3 tm_string VARCHAR2(30);
4 BEGIN
5 SELECT SYSTIMESTAMP INTO tm_stamp FROM dual;
6 dbms_output.put_line(tm_stamp);
7 SELECT SYSTIMESTAMP INTO tm_string FROM dual;
8 dbms_output.put_line(tm_string);
9 END;
10 /
24-OCT-14 11.17.35.180000 AM
DECLARE
*
ERROR at line 1:
ORA-06502: PL/SQL: numeric or value error
ORA-06512: at line 7
SQL>
因此,tm_string无法存储时间戳,因为tm_stamp是字符串类型而不是时间戳。
正确的方法是明确地将其转换为字符串。
SQL> DECLARE
2 tm_stamp TIMESTAMP;
3 tm_string VARCHAR2(50);
4 BEGIN
5 SELECT TO_CHAR(systimestamp, 'DD-MON-YYYY HH24:MI:SS.FF TZH:TZM') INTO tm_string FROM dual;
6 dbms_output.put_line(tm_string);
7 END;
8 /
24-OCT-2014 11:25:20.060000 +05:30
PL/SQL procedure successfully completed.
SQL>
答案 1 :(得分:0)
TIMESTAMPTZ
的格式为well documented。我们目前使用the following code。
如果您使用的是Java SE 8和ojdbc8,则可以使用getObject(int, OffsetDateTime.class)
。如果您使用getObject(int, ZonedDateTime.class)
,则可能会受到bug 25792016的影响。