.NET DateTime オブジェクトのミリ秒の不一致の処理
外部リクエストから受信したタイムスタンプをデータベース値 (SQL Server など) と比較する場合、精度の違いにより比較の問題が発生する可能性があります。 これは多くの場合、データベースのミリ秒精度に起因しますが、受信データには存在しない可能性があります。 これを修正するには、.NET DateTime
オブジェクトからミリ秒を削除する必要があります。
簡潔な解決策には、Ticks
プロパティを直接操作することが含まれます。
<code class="language-csharp">DateTime dateTime = ...; // Your DateTime object dateTime = new DateTime(dateTime.Ticks - (dateTime.Ticks % TimeSpan.TicksPerSecond), dateTime.Kind);</code>
あるいは、もう少し読みやすいバージョンでも同じ結果が得られます。
<code class="language-csharp">dateTime = dateTime.AddTicks(-(dateTime.Ticks % TimeSpan.TicksPerSecond));</code>
どちらのメソッドも、Kind
プロパティ (Local、Utc、または Unspecified) を維持しながら、ミリ秒を効果的に切り捨てます。
再利用性を高めるには、拡張メソッドの作成を検討してください。
<code class="language-csharp">public static DateTime TruncateMilliseconds(this DateTime dateTime, TimeSpan timeSpan) { if (timeSpan == TimeSpan.Zero) return dateTime; // Handle zero TimeSpan if (dateTime == DateTime.MinValue || dateTime == DateTime.MaxValue) return dateTime; // Preserve special values return dateTime.AddTicks(-(dateTime.Ticks % timeSpan.Ticks)); }</code>
この拡張メソッドにより、柔軟な切り捨てが可能になります:
<code class="language-csharp">dateTime = dateTime.TruncateMilliseconds(TimeSpan.FromMilliseconds(1)); // Truncate to whole milliseconds dateTime = dateTime.TruncateMilliseconds(TimeSpan.FromSeconds(1)); // Truncate to whole seconds dateTime = dateTime.TruncateMilliseconds(TimeSpan.FromMinutes(1)); // Truncate to whole minutes // ... and so on</code>
これらのメソッドは、DateTime
オブジェクトを比較する際のミリ秒の不一致を排除する簡単な方法を提供し、正確なタイムスタンプの比較を保証します。
以上が.NET DateTime オブジェクトからミリ秒を効率的に切り捨てるにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。