2

Oracle db からデータを取得し、このデータを json に入れて別の場所で使用しようとしましたが、timestamptz の変換に問題があります。オラクルは、「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)

ところで、以前は「XX:XX」のような数値形式でタイムゾーンを取得していましたが、このコードも機能しませんでしたが、super.setValue(metaData.getColumnName(i), ts.stringValue(null))この方法でこの魔法を機能させて、nullpointerexception をスローします。javadocs にあるものをすべて試したので、助けてください。

4

2 に答える 2

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_stamp は文字列型でタイムスタンプではないため、tm_string はタイムスタンプを格納できません。

正しい方法は、明示的に文字列に変換することです。

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>
于 2014-10-24T05:55:56.203 に答える