6

日時フィールド (P_DT) があり、P_DT が入力 UNIX タイムスタンプよりも大きいすべての結果を返したいと考えています。

Oracleには、役立つ組み込み関数がありますか?

私の検索では、DateTime から Unix への結果は見つかりましたが、Unix から DateTime への結果は見つかりませんでした...

4

2 に答える 2

16

組み込み関数はありません。しかし、それを書くのは比較的簡単です。Unixタイムスタンプは、1970年1月1日からの秒数であるため

CREATE OR REPLACE FUNCTION unix_ts_to_date( p_unix_ts IN NUMBER )
  RETURN DATE
IS
  l_date DATE;
BEGIN
  l_date := date '1970-01-01' + p_unix_ts/60/60/24;
  RETURN l_date;
END;

あなたが呼ばれているのを見ることができます

SQL> select unix_ts_to_date( 1336822620 ) from dual;

UNIX_TS_TO_DATE(133
-------------------
2012-05-12 11:37:00
于 2012-05-11T15:40:02.643 に答える