ホームページ > データベース > mysql チュートリアル > 時間を無視して日付のみに基づいて MySQL レコードを効率的に取得するにはどうすればよいですか?

時間を無視して日付のみに基づいて MySQL レコードを効率的に取得するにはどうすればよいですか?

Barbara Streisand
リリース: 2024-12-13 17:31:12
オリジナル
474 人が閲覧しました

How to Efficiently Retrieve MySQL Records Based on Date Only, Ignoring Time?

時刻を除き、日付のみに基づいてレコードを取得する

問題:

日時カラムを持つ MySQL テーブルがあります。時間を考慮せずに、特定の日に該当するレコードを選択する方法が必要です

解決策:

これを実現するには、パフォーマンスが低下し、インデックスが使用できなくなるため、WHERE 句で DATE() 関数を使用しないようにします。代わりに、BETWEEN 演算子を使用して、目的の日付を含む日の範囲を指定します。

SELECT * FROM tablename
WHERE columname BETWEEN '2012-12-25 00:00:00' AND '2012-12-25 23:59:59'
ログイン後にコピー

または、MySQL バージョンの場合、一日の終わりに「23:59:59」を指定することに制限がある場合があります。次のクエリを使用できます:

SELECT * FROM tablename
WHERE columname >= '2012-12-25 00:00:00'
AND columname < '2012-12-26 00:00:00'
ログイン後にコピー

このアプローチでは、時間コンポーネント。

以上が時間を無視して日付のみに基づいて MySQL レコードを効率的に取得するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート