我在我的应用程序中使用 NodaTime 和 Entity Framework Core。我正在使用 AutoMapper 从我的模型(使用 LocalTime)转换为我的实体(使用 Timespan,它映射到 Sql Server 中的时间)。我这样做是为了避免 EF ValueConversions 的陷阱。
当从实体到模型(即时间跨度到本地时间)时,我找到了“官方”方法(https://github.com/nodatime/nodatime/issues/148):
LocalTime.FromTicksSinceMidnight(timespan.Ticks)
但是,从模型到实体(即 LocalTime 到 Timespan),我不确定最好的方法是什么。日期和时间似乎太棘手,无法仅获取小时、分钟等,例如:
new TimeSpan(localTime.Hour, localTime.Minute, localTime.Second, localTime.Second, localTime.Millisecond)
我应该像从 LocalTime 到 Timespan 一样使用刻度吗?
TimeSpan.FromTicks(localTime.TickOfSecond)
最佳答案
从 LocalTime
转换为 TimeSpan
,您确实可以使用刻度 - 但您需要 TickOfDay
:
TimeSpan timeSinceMidnight = TimeSpan.FromTicks(localTime.TickOfDay);
关于sql-server - 从 LocalTime 转换为 TimeSpan,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59688602/