|
2019/02/07(Thu) 23:09:01 編集(投稿者)
■No90088 (健太 さん) に返信 > SQLにてデータベースを取得する際、
どのデータベース製品でしょうか? SQL Server、Oracle、Access 等々、それぞれで SQL が異なります。
> dayというフィールドに入っている日付が
Oracle あたりなら OK ですが、 SQL Server や Access の場合は「DAY 関数」と競合するので、 フィールドに day と名前を付けるのは、避けた方が無難かと思います。
> フィールドでは2017/2/7のようなyyyy/m/y型で入っております 。
yyyy/m/d 形式ではなく yyyy/m/y なのだとすると、 そもそも day 情報が無いという罠。
> 2年前[2017/2/1]から 投稿頂いた日時は 2019/02/07 16:59:35 ですが、 2017/02/07 ではなく、2017/02/01 なのですね?
※2017/02/01 だとすると、約 2.015 年前(736.666 日前) 換算。
> where句にてこのようなことは可能でしょうか?
対象のフィールドが日付型なら、
WHERE フィールド >= 「2年前の日付」 AND フィールド <= 「現在の日付」
で良いのではないでしょうか。
たとえば SQL Server を例に挙げると、 現在の日付は、GETDATE 関数や SYSDATETIME 関数で得られます。 過去の日付を算出したいなら、DATEADD 関数です。
現在日時(2019/02/07 18時頃) の 2 年前の日付を算出したいなら、 SQL Server では『CAST(DATEADD(YEAR, -2, GETDATE()) AS DATE)』 Oracle では『TRUNC(SYSDATE) - INTERVAL '2' YEAR』という構文で、 「2017/02/07」な日付値を得ることができます。
「2017/02/01」相当が必要なのであれば、 SQL Server 2012 以降で『DATEFROMPARTS(YEAR(GETDATE()) - 2, MONTH(GETDATE()), 1)』 Oracle だと『TO_DATE(TO_NUMBER(TO_CHAR(SYSDATE, 'YYYYMM') - 200), 'YYYYMM')』 とか。
|