15

クエリで 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

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

4

3 に答える 3

8

@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

よろしく!

于 2014-03-07T09:14:49.947 に答える
-2

ALTER SESSION SET TIME_ZONE = '+01:00'; を使用します。あなたのSELECTの前に

于 2015-10-27T18:11:21.583 に答える