從 .NET DateTime 截斷毫秒
SQL Server 時間戳中儲存的毫秒固有精度在將它們與缺乏此精度的傳入請求時間戳進行比較時可能會帶來挑戰。為了解決這種差異,截斷毫秒是常見的解決方案。
可以使用以下方法實現此目的:
<code class="language-csharp">DateTime dateTime = ... 任何值 ...; dateTime = new DateTime( dateTime.Ticks - (dateTime.Ticks % TimeSpan.TicksPerSecond), dateTime.Kind );</code>
或者,可以使用更簡潔的語法:
<code class="language-csharp">dateTime = dateTime.AddTicks(-(dateTime.Ticks % TimeSpan.TicksPerSecond));</code>
此外,擴充方法可以概括此概念:
<code class="language-csharp">public static DateTime Truncate(this DateTime dateTime, TimeSpan timeSpan) { // 处理无效输入 if (timeSpan == TimeSpan.Zero) return dateTime; if (dateTime == DateTime.MinValue || dateTime == DateTime.MaxValue) return dateTime; return dateTime.AddTicks(-(dateTime.Ticks % timeSpan.Ticks)); }</code>
要使用此擴充方法,只需指定所需的截斷間隔:
<code class="language-csharp">dateTime = dateTime.Truncate(TimeSpan.FromMilliseconds(1)); // 截断到整毫秒 dateTime = dateTime.Truncate(TimeSpan.FromSeconds(1)); // 截断到整秒</code>
以上是如何從 .NET DateTime 截斷毫秒?的詳細內容。更多資訊請關注PHP中文網其他相關文章!