sql-server - 从 LocalTime 转换为 TimeSpan

标签 sql-server automapper nodatime localtime entity-framework-core-3.1

我在我的应用程序中使用 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/

相关文章:

sql - 在日期列上使用 ISNULL

sql-server - 删除 MS SQL Server 中的列

Automapper:将 List<string> 映射到 List<Class>

c# - 使用NodaTime,如何将Instant转换为对应系统的ZonedDateTime?

c# - 如何在 ServiceStack.OrmLite 中自定义复杂类型的序列化/反序列化

sql-server - 多对多表上的递归父级到子级到父级

sql-server - 更新日期时间变量中的年份

c# - AutoMapper.dll 中出现“AutoMapper.AutoMapperMappingException”

c# - Automapper 有时无法映射通过 ForMember 设置的属性

c# - Noda Time (C#) 魔术解析 JSON(假定为 ISO 8601)日期。例如1396949418557