C# と VB.NET の質問掲示板

ASP.NET、C++/CLI、Java 何でもどうぞ

ログ内検索
  • キーワードを複数指定する場合は 半角スペース で区切ってください。
  • 検索条件は、(AND)=[A かつ B] (OR)=[A または B] となっています。
  • [返信]をクリックすると返信ページへ移動します。
キーワード/ 検索条件 /
検索範囲/ 強調表示/ ON (自動リンクOFF)
結果表示件数/ 記事No検索/ ON
大文字と小文字を区別する

No.90090 の関連記事表示

<< 0 >>
■90090  Re[1]: SQLのwhere句で日付が2年前から現在のならばという条件
□投稿者/ 魔界の仮面弁士 -(2019/02/07(Thu) 18:02:47)
    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')』
    とか。
記事No.90088 のレス /過去ログ155より / 関連記事表示
削除チェック/



<< 0 >>

パスワード/

- Child Tree -