ホームページ >データベース >mysql チュートリアル >MySQL レコードを DateTime フィールドの日付でグループ化するにはどうすればよいですか?

MySQL レコードを DateTime フィールドの日付でグループ化するにはどうすればよいですか?

Barbara Streisand
Barbara Streisandオリジナル
2024-10-31 00:28:30309ブラウズ

How to Group MySQL Records by Date from DateTime Fields?

MySQL グループ化クエリで日時フィールドを処理する方法

日時フィールドを含むデータベース テーブルを操作する場合、レコードをグループ化するのが難しい場合があります。日付コンポーネントのみに基づきます。 MySQL には、グループ化を目的として日時フィールドを日付フィールドに変換するためのオプションがいくつか用意されています。

DATE() 関数

効果的な方法の 1 つは、DATE() 関数を使用することです。 。 DATE() 関数は、時刻コンポーネントを無視して、日時フィールドから日付部分を抽出します。たとえば、follow_date という名前の日時フィールドがある場合、次のクエリを使用して、日付に基づいてレコードをグループ化できます。

<code class="sql">select * from follow_queue group by DATE(follow_date);</code>

このクエリは、時間情報を実質的に無視して、日付コンポーネントごとにレコードをグループ化します。

CAST() 関数

もう 1 つの方法は、CAST() 関数を使用して日時フィールドを日付フィールドに明示的に変換することです。 CAST() 関数は 2 つの方法で使用できます:

  • フィールド変換として: datetime フィールド全体を日付フィールドにキャストできます。例:
<code class="sql">select * from follow_queue group by CAST(follow_date AS date);</code>
  • グループ化句として: GROUP BY 句内で CAST() を使用して、その場でフィールドを変換することもできます。例:
<code class="sql">select * from follow_queue group by follow_date cast follow_date as date</code>

後者のアプローチはすべてのデータベース エンジンでサポートされているわけではないことに注意してください。データベースのドキュメントで互換性を確認してください。

以上がMySQL レコードを DateTime フィールドの日付でグループ化するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。