web-dev-qa-db-ja.com

オフセット付きタイムゾーン付きタイムスタンプへのORACLEキャスト

クエリのDATE値をTIMESTAMP WITH TIME ZONEにキャストする必要がありますが、現在、EFで使用するのが有効ではないTimeZoneリージョン(「ヨーロッパ/パリ」)を取得しています。

たとえば、これを行う場合:

select CAST(FECHA AS TIMESTAMP WITH TIME ZONE) from test;

私は現在この出力を取得しています:

07/03/14 09:22:00,000000000 EUROPE/PARIS

ただし、次のようにする必要があります。

07/03/14 09:22:00,000000000 +01:00

これを達成する方法はありますか?

10
Farlop

DATETIMESTAMPにキャストしてから、 FROM_TZ このタイムスタンプをタイムゾーン付きのタイムスタンプに変換するには:

SQL> SELECT from_tz(CAST (SYSDATE AS TIMESTAMP), '+01:00') tz FROM dual;
TZ
-------------------------------------------------
07/03/14 09:47:06,000000 +01:00
17
Vincent Malgrat

@Vincent Malgratソリューションでは、TIMEZONE_HOURを取得してから、クエリで使用するようにフォーマットする必要があります。自動的に作成する機会があるかどうかはわかりません。

いくつかの関数をネストすることをお勧めします。それは最もクリーンなソリューションではありませんが、私にとってはうまくいきます

SELECT TO_TIMESTAMP_TZ(TO_CHAR(CAST(FECHAHORA AS TIMESTAMP WITH TIME ZONE), 'DD-MM-YY HH24:MI:SS TZH:TZM'), 'DD-MM-YY HH24:MI:SS TZH:TZM' )FROM TEST;

結果は次のようになります

03/03/14 09:58:02,000000000 +01:00

よろしく!

6
RandomUser