从 .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中文网其他相关文章!