.NETエンジニア・プログラマ向けの技術情報・業界ニュースをお届けします。

  1. FEnet.NETナビ
  2. .NETコラム
  3. データベース
  4. SQL Server
  5. SQL Serverの日付データ取得の関数6つ|文字列や数値で取得する方法も説明

SQL Serverの日付データ取得の関数6つ|文字列や数値で取得する方法も説明

  • SQL Server
  • データベース
公開日時:   更新日時:
SQL Serverの日付データ取得の関数6つ|文字列や数値で取得する方法も説明
この記事でわかること
    基本情報技術者試験の試験対策はこちら>>

    システム
    エンジニア
    SQL Serverの日付データ取得について教えてください。

    プロジェクト
    マネージャー
    SQL Serverの日付型3種類と関数などを紹介します。

    SQL Serverの日付型3種類


    SQL Serverでは、日付型のデータ型が数種類用意されていますが、ここではよく使う3つの種類を確認していきます

    1:DATE型

    日付を格納するのに使用するデータ型です。形式は「YYYY-MM-DD」です。ハイフン(-)で区切られている箇所は、スラッシュ(/)やピリオド(.)で区切ることも可能です。
    DATE型の最小単位は日であるため、時間まで不要な場合に使用する型となります。

    表示例①:2020-08-27
    表示例②:2020/08/27
    表示例③:2020.08.27

    2:DATETIME型

    日付・時刻を格納するのに使用するデータ型です。形式は「YYYY-MM-DD hh:mm:dd[.mmm]」です。最小単位は3.33msとなります。

    表示例①:2020-08-27 11:12:13
    表示例②:2020/08/27 11:12:13.487

    3:DATETIME2型

    日付・時刻を格納するのに使用するデータ型です。形式は「YYYY-MM-DD hh:mm:dd[.nnnnnnn]」です。最小単位は100nsとなります。

    表示例①:2020-08-27 11:12:13
    表示例②:2020/08/27 11:12:13.0000001

    SQL Serverの日付データ取得の関数6つ

    以上SQL SERVERの日付型であるDATE、DATETIME、DATETIME2型について紹介しました。次に、これらの日付型を取得する関数について6つほど紹介していきます。

    1:同じ日付のデータを取得する


    まずは、数字による日付からSQL Serverの日付データ型を取得するケースについて紹介していきます。厳密にミリ秒まで取得する場合と年月日までの日付データ型を取得する2つのケースについて説明します。

    完全に同じデータのみ取得する方法

    指定した日付の日付データ型を得たい場合はDATETIME2FROMPARTS関数を使って得ることができます。

    構文は以下の通りです。年月日に加えて、秒、ミリ秒、有効桁数を指定して使います。

    具体例は以下の通りです。以下のように有効桁数を指定することでdatetime2型の秒の桁数を指定することができます。

    日付が一致するデータを取得する方法

    先ほどは厳密な日付データを得る方法について説明しました。ミリ秒などを含まない年月日のみの日付型を得たい場合はDATEFROMPARTS関数を使って得ることができます。

    構文は以下の通りです。

    具体例は以下の通りです。

    2:指定した日付より前のデータを取得する

    指定日時の日付型データを得る方法を説明しました。もっとも、指定した日付だけではなく、その前後のデータを得たいケースがあります。これから指定した日付よりも前のデータを取得する方法を説明します。

    DATEADD関数を使うことで前後の日付を得ることができます。
    datepartはdayやmonthなどを指定します。numberは操作したい数を入力します。dateには操作の基準となる日付を入力します。

    以下の例では2006年8月30日のmonthに対して、-1操作するという意味になります。結果は1か月前の2006年7月30日が得られます。

    DATEADD関数は指定した日付に対して加算減算ができる関数になります。この関数を使って指定した日付より前のデータを取得できます。

    3:指定した日付より後のデータを取得する

    続いて指定した日付よりも後のデータを取得する方法を説明します。

    後のデータを得たい場合についても同様にDATEADD関数を使うことで得ることができます。numberに正の値を指定することで後のデータを得ることができます

    以下の例では2006年8月30日のdayに対して、1操作するという意味になります。結果は1日後の2006年8月30日が得られます。

    4:特定の期間のデータを取得する

    現在時刻のデータを取得したい場合はGETDATE()関数を使って得ることができます。ここで得られる日付はSQL Serverが稼働しているシステムの日時に依存します。

    5:指定の期間外のデータを取得する

    与えた日付以外の日付型を得たい場合は、DATEADD、EOMONTH、SWITCHOFFSET、TODATETIMEOFFSETの4種類の関数を使って得ることができます。

    これらの関数は指定した日付の前後の日付データを得たり、異なるタイムゾーンの日付データを得るための関数になります。

    6:指定した日付の末日のデータを取得する

    指定した日付の月の末日を取得したい場合はEOMONTH関数を使って得ることができます。構文は以下の通りです。

    EOMONTH ( start_date [, month_to_add ] )

    以下の例ではEMONTHに与えた2011年12月1日の末日を取得することができます。

    第二引数が与えられていない場合は、指定した日の月末である31日という結果が得られます。

    (1 row(s) affected)

    仮に-1が与えられていた場合はその前の月の結果が得られます。

    (1 row(s) affected)

    SQL Serverで日付や時刻の一部を取得する方法3つ


    SQL Serverでは日付データから年月日それぞれを抽出する関数が用意されています。3つの関数について解説します。
    SQLを使ったレコード操作の際に、これらの関数を駆使することで特定の日付ではなく特定の年や月などに範囲を広げることができます。

    1:年のデータ

    YEAR関数を使うことで日付から年のデータだけを抽出することができます。構文は以下の通りです。

    具体例は以下の通りです。カッコ内に日付データから年だけを抽出することができます。

    2:月のデータ

    年のデータを抽出するのと同様、MONTH関数を使うことで日付から月のデータだけを抽出することができます。構文は以下の通りです。

    具体例は以下の通りです。カッコ内の日付データから月だけを抽出することができます。

    3:日のデータ

    今までの例と同様、DAY関数を使うことで日付から日のデータだけを抽出することができます。構文は以下の通りです。

    具体例は以下の通りです。カッコ内の日付データから日だけを抽出することができます。

    SQL Serverで指定の要素を文字列で取得する方法


    今までは指定した日付の日付型を得る方法について説明しました。つまり、DATE、DATETIME、DATETIME2型のいずれかが得られる関数を紹介しました。
    そこで、日付型ではなく文字列や整数として得たい場合について紹介します。

    まずは文字列として取得する方法について説明いたします。構文は以下の通りです。

    指定したdatepartについての文字列nvachar型を得ることができます。datepartにはyearだけではなくmonthやdayなどを指定することができます。

    SQL Serverで指定の要素を数値で取得する方法


    続いて数値として取得する方法について説明します。構文は以下の通りです。

    指定したdatepartについての数値int型を得ることができます。datepartにはyearだけではなくmonthやdayなどを指定することができます。

    システム
    エンジニア
    SQL Serverの日付データ取得方法がわかりました。

    プロジェクト
    マネージャー
    紹介した方法を参考に実践してみましょう。

    SQL Serverで日付データを取得できるようになろう


    この記事では、SQL Serverの日付データ型と日付型を得るための関数を紹介しました。日付型にはDATE、DATETIME、DATETIME2型の3種類があります。また、それらの日付型を得るための代表的な関数を6つほど紹介しました。

    併せて日付から特定のデータを抽出する方法や、日付を整数や文字列として得る方法についても説明しました。

    日付データを扱えるようになるメリットとしては、データベースから特定期間のレコードを取得したいケースなどに活用することができます。この機会に使い方をマスターして、開発現場で活用していきましょう。

    FEnet.NETナビ・.NETコラムは株式会社オープンアップシステムが運営しています。
    株式会社オープンアップシステムロゴ

    株式会社オープンアップシステムはこんな会社です

    秋葉原オフィスには株式会社オープンアップシステムをはじめグループのIT企業が集結!
    数多くのエンジニアが集まります。

    秋葉原オフィスイメージ
    • スマホアプリから業務系システムまで

      スマホアプリから業務系システムまで

      スマホアプリから業務系システムまで開発案件多数。システムエンジニア・プログラマーとしての多彩なキャリアパスがあります。

    • 充実した研修制度

      充実した研修制度

      毎年、IT技術のトレンドや社員の要望に合わせて、カリキュラムを刷新し展開しています。社内講師の丁寧なサポートを受けながら、自分のペースで学ぶことができます。

    • 資格取得を応援

      資格取得を応援

      スキルアップしたい社員を応援するために資格取得一時金制度を設けています。受験料(実費)と合わせて資格レベルに合わせた最大10万円の一時金も支給しています。

    • 東証プライム上場企業グループ

      東証プライム上場企業グループ

      オープンアップシステムは東証プライム上場「株式会社オープンアップグループ」のグループ企業です。

      安定した経営基盤とグループ間のスムーズな連携でコロナ禍でも安定した雇用を実現させています。

    株式会社オープンアップシステムに興味を持った方へ

    株式会社オープンアップシステムでは、開発系エンジニア・プログラマを募集しています。

    年収をアップしたい!スキルアップしたい!大手の上流案件にチャレンジしたい!
    まずは話だけでも聞いてみたい場合もOK。お気軽にご登録ください。

    株式会社オープンアップシステムへのご応募はこちら↓
    株式会社オープンアップシステムへのご応募はこちら↓

    SQLServer新着案件New Job