SQL Server で日付部分のみを使用して日時値を効率的に比較するにはどうすればよいですか?
Jan 05, 2025 pm 02:41 PMSQL Server の日付のみと日時値を比較する
特定の日に作成されたレコードについてデータベースにクエリを実行する場合は、次の点を考慮することが重要です。列の日時の性質。等号演算子を使用して日時フィールドを日付部分のみと比較すると (例: U.DateCreated = '2014-02-07')、予期した結果が返されない場合があります。
解決策 1: 日付範囲を使用する
日時フィールドと日付部分のみを正確に比較するには、日付を使用しますrange:
Select * from [User] U where U.DateCreated >= '2014-02-07' and U.DateCreated < dateadd(day,1,'2014-02-07')
このアプローチにより、時刻コンポーネントに関係なく、'2014-02-07' に作成されたレコードが確実に取得されます。
WHERE 句の関数を回避する理由
で関数 (変換など) を使用することはお勧めできません。 WHERE 句を使用する主な理由は次の 2 つです:
- インデックス最適化の損失: データに対する関数により、オプティマイザがインデックスを使用できなくなり、クエリが遅くなる可能性があります。
- 高い計算オーバーヘッド: 関数を適用すると、かなりの計算オーバーヘッドが発生する可能性があります。大規模なデータセット。
日付範囲のベスト プラクティス
日付と時刻の範囲をクエリするときに最適なパフォーマンスと精度を得るには、次の形式を使用することをお勧めします。 :
WHERE col >= '20120101' AND col < '20120201'
以上がSQL Server で日付部分のみを使用して日時値を効率的に比較するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

人気の記事

人気の記事

ホットな記事タグ

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











Alter Tableステートメントを使用してMySQLのテーブルをどのように変更しますか?

Linuxでmysqlを実行します(phpmyAdminを使用してポッドマンコンテナを使用して/なし)

MACOSで複数のMySQLバージョンを実行する:ステップバイステップガイド

共通の脆弱性(SQLインジェクション、ブルートフォース攻撃)に対してMySQLを保護するにはどうすればよいですか?

人気のあるMySQL GUIツール(MySQL Workbench、PhpMyAdminなど)は何ですか?
