-1

今日の時間が午後 3 時を超える場合、昨日の午後 3 時から今日の午後 3 時までのテーブルからレコードを選択する必要がある SQL クエリがあります。

今日の時刻がそれよりも短い場合 (今日の時刻が午後 1:00 の場合など)。次に、クエリは今日の時刻を午後 1:00 として取得する必要があります (レコードが返されるはずです)。

昨日の午後 3:00 から今日の午後 3:00 までの時間を取得する必要があります。

4

2 に答える 2

2

これを処理する最善の方法は、IF ステートメントを使用することです。

IF TO_CHAR(SYSDATE, 'HH24') >= 15 THEN 

  SELECT x.*
    FROM YOUR_TABLE x
   WHERE x.date_column BETWEEN TO_DATE(TO_CHAR(SYSDATE -1, 'YYYY-MM-DD')|| ' 15:00:00', 'YYYY-MM-DD HH24:MI:SS')
                           AND TO_DATE(TO_CHAR(SYSDATE, 'YYYY-MM-DD')|| ' 15:00:00', 'YYYY-MM-DD HH24:MI:SS')

ELSE

  SELECT x.*
    FROM YOUR_TABLE x
   WHERE x.date_column BETWEEN TO_DATE(TO_CHAR(SYSDATE -1, 'YYYY-MM-DD')|| ' 15:00:00', 'YYYY-MM-DD HH24:MI:SS')
                           AND SYSDATE

END IF;

条件付きの WHERE 句はサーガブルではありません。

以前:

私の理解が正しければ、あなたは最終日以内に記録を取得したいと考えています。現在時刻が午後 3 時以降の場合は、時刻を午後 3 時に設定する必要があります。午後 3 時より前の場合は、現在の時刻を使用してください...

SELECT x.*
  FROM YOUR_TABLE x
  JOIN (SELECT CASE
                 WHEN TO_CHAR(SYSDATE, 'HH24') >= 15 THEN 
                  TO_DATE(TO_CHAR(SYSDATE, 'YYYY-MM-DD')|| ' 15:00:00', 'YYYY-MM-DD HH24:MI:SS')
                 ELSE SYSDATE
               END AS dt
          FROM DUAL) y ON x.date_column BETWEEN dt - 1 AND dt

ノート:

dt - 1Oracle DATE から 24 時間が差し引かれることを意味します。

参照:

于 2011-05-18T06:34:41.050 に答える
1

IFステートメントは必要ありません。これは、単純なSQLで簡単に解決できます。

私のテーブルT23には、日付のあるレコードがいくつかあります。午後3時のサンプルを次に示します。

SQL> select id, some_date from t23
  2  where to_char(some_date,'HH24') = '15'
  3  /

        ID SOME_DATE
---------- ---------
        14 16-MAY-11
        38 17-MAY-11
        62 18-MAY-11
        81 19-MAY-11

SQL>

現在の時刻は午後3時より前なので、クエリは5月17日と5月18日のレコードを返しますが、ID=62のレコードは返しません...

SQL> select to_char(sysdate, 'DD-MON-YYYY HH24:MI') as time_now
  2  from dual
  3  /

TIME_NOW
-----------------
18-MAY-2011 10:45

SQL> select id, to_char(some_date, 'DD-MON-YYYY HH24:MI') as dt
  2  from t23
  3  where some_date between trunc(sysdate-1)+(15/24)
  4                  and least( trunc(sysdate)+(15/24), sysdate)
  5  /

        ID DT
---------- -----------------
        38 17-MAY-2011 15:00
        39 17-MAY-2011 16:00
        40 17-MAY-2011 17:00
        41 17-MAY-2011 18:00
        42 17-MAY-2011 19:00
        43 17-MAY-2011 20:00
        44 17-MAY-2011 21:00
        45 17-MAY-2011 22:00
        46 17-MAY-2011 23:00
        47 18-MAY-2011 00:00
        48 18-MAY-2011 01:00
        49 18-MAY-2011 02:00
        50 18-MAY-2011 03:00
        51 18-MAY-2011 04:00
        52 18-MAY-2011 05:00
        53 18-MAY-2011 06:00
        54 18-MAY-2011 07:00
        55 18-MAY-2011 08:00
        56 18-MAY-2011 09:00
        57 18-MAY-2011 10:00

20 rows selected.

SQL>
于 2011-05-18T09:49:13.717 に答える