36

タイムスタンプ フィールドがあり、Oracle のクエリでその日付部分を比較したいだけです

それ、どうやったら出来るの、

SELECT *
FROM Table1
WHERE date(field1) = '2012-01-01' 
4

3 に答える 3

74

日付部分を切り捨てることができます:

select * from table1 where trunc(field1) = to_date('2012-01-01', 'YYYY-MM-DD')

このアプローチの問題点はfield1、関数呼び出しのためにインデックスが使用されないことです。

代わりに(そしてよりインデックスフレンドリー)

select * from table1 
 where field1 >= to_timestamp('2012-01-01', 'YYYY-MM-DD') 
   and field1 < to_timestamp('2012-01-02', 'YYYY-MM-DD')
于 2012-09-26T20:06:40.927 に答える
4

日付を切り捨てることができます

SELECT *
FROM Table1
WHERE trunc(field1) = to_Date('2012-01-01','YYY-MM-DD')

その他の例については、SQL Fiddleを参照してください。

于 2012-09-26T20:14:46.610 に答える
0

to_dateフォーマットは私のために働いた。日付形式を考慮してください: MON-MM.-

t.start_date >= to_date('14.11.2016 04:01:39', 'DD.MM.YYYY HH24:MI:SS')
t.start_date <=to_date('14.11.2016 04:10:07', 'DD.MM.YYYY HH24:MI:SS')
于 2016-11-15T06:19:07.327 に答える