SQL 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 サイトの他の関連記事を参照してください。