- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在我的 .NET Core 3.1 项目中,我目前正在将与时间相关的代码移至 NodaTime。
我在翻译一些查询时遇到了问题,因为在 NodaTime 中两个 Instants 之间的差异产生了一个 Duration,而在 Postgres 中两个 TIMESTAMP 之间的差异产生了一个 INTERVAL。
Npgsql 将 Instant 映射到 TIMESTAMP,但 INTERVAL 是 Period。
假设我有一个名为“Visit”的实体,它有一个 ID 和两次:“到达”和“离开”。 (这不是我的实际用例,我有几个实体有这个问题,所以这是一个最小的例子)
public class Visit
{
public int Id { get; set; }
public Instant Arrived { get; set; }
public Instant Left { get; set; }
}
现在我想找到访客停留时间少于给定时间的访问:
public async Task<List<Visit>> FindVisitsShorterThan(DbSet<Visit> dbSet, Duration duration)
{
var visits =
from visit in dbSet
where (visit.Left - visit.Arrived) < duration
select visit;
return await visits.ToListAsync();
}
如果我这样做,Npgsql 会提示类似 System.InvalidCastException: Can't write CLR type NodaTime.Duration with handler type TimestampHandler
- 因为不支持持续时间。
另一方面,如果我将 Duration 转换为 Period,NodaTime 会提示,因为从它的角度来看,这种差异是 Duration,无法与 < 与 Period 进行比较。
我可以做几件事,但没有一件看起来很理想:
有没有更好的办法?
最佳答案
这确实是当前 Npgsql EF 对 NodaTime 类型支持的不幸限制。
好消息是我刚刚实现了上面的内容,以及其他一些 NodaTime 算术翻译 - see this tracking issue .这将包含在下周即将发布的 EF Core 5.0 版本中 - 只需等待几天,一切都会好起来的。
关于c# - 如果 NodaTime 使用 Duration 而 Postgres 使用 INTERVAL/Period,如何在 EF Core 中进行时间戳运算?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64741399/
我正在尝试使用普通的 Windows Metro 风格应用程序执行以下操作: public class MyButton : Button { public Duration Duration
有下表 "CREATE TABLE IF NOT EXISTS user_preferences (" + " user_id text,"
假设我有: t := 10 * time.Second // 10s, 当 time.Second 再次应用时,幕后发生了什么? tt := t * time.Second // -2346317h4
在 Java 8 中, Duration 类(class)提供了 toDays 方法,返回总天数作为与日历天无关的 24 小时时间块的计数。 在 Java 9 中,Duration上课得心应手 to…
这很奇怪,经过数小时的测试我仍然无法弄清楚。 好的,这就是我要做的:合并两个视频,也就是一个接一个地追加。 我拍摄了两个视频,然后有两个网址。然后我使用以下方法创建了两个 AVURLAsset: A
正如标题所说,我得到一个字符串'01:23.290',它看起来像一个Duration,但不是。现在我需要用它来与真实的 Duration 进行比较,而我不知道如何处理它。有什么方法吗? 最佳答案 使用
std::chrono::duration的默认构造函数定义如下: constexpr duration() = default; (例如,参见 cppreference.com 或 libstdc+
我正在尝试在我的应用程序中录制视频,我注意到在显示它们的duration 时,我看到了错误的分钟\秒。只有通过以下代码录制的视频才会发生这种情况。通过其他应用录制的视频,时长显示在右侧: publi
我对 AVPlayer.timeControlStatus 属性进行 KVO 处理,播放器有一个 AVPlayerItem。 该视频是托管在远程服务器上的 mpeg4 编码的 10 秒视频文件: le
我正在使用 Spring Reactor Core 3.0.6 并且我有一个返回 Flux 的方法: public Flux createFlux(){ return Flux.,String
当然,我在这里做了一些愚蠢的事情,但我在编译我的简单秒表类时遇到了问题。错误是: /usr/include/c++/4.9/chrono:246:2: error: static assertion
此代码在 gcc-4.8 上编译但在 clang-3.3 上失败?以及如何使这段代码可以在 clang 上编译? =\ #include #include #include void sleep
我正在尝试编写一个允许用户指定 chrono::duration 的函数,例如 chrono::seconds 并返回 chrono 的结果::duration::count. 我可以使用以下模板函数
我不明白在 Go 中划分一个 time.Duration 是什么意思。 例如,这是 super 可爱的: d,_ := time.ParseDuration("4s") fmt.Println(d/4
我是一个初学者程序员,在 scala 中有一个非常简单的问题,我想将一个 long var 转换为 Duration (import scala.concurrent.duration.Duratio
我想知道这两者之间的区别是什么 boost::timed_mutex _mutex; if(_mutex.timed_lock(boost::get_system_time() + boost::po
我正在尝试实现 JUnit 测试来测试参与者。 我有这个 ActorTest : import org.junit.Test; import play.libs.Akka; import playte
假设您有一个涉及两个 Web 应用程序的项目(将共享 DAL/DAO/BO 程序集和一些 OSS 库): 一个半复杂的管理应用程序,使用 Windows Live ID 进行身份验证,并且还能够与各种
根据 moment.js documentation您可以创建 moment 的本地实例,以使用全局设置以外的其他语言环境来格式化日期。 使用 format() 效果很好,但我如何在本地实例上使用 d
我的项目提示“调用中有一个额外的参数‘duration’”。这是它发生的地方 required init(coder aDecoder: NSCoder) { workout = Workou
我是一名优秀的程序员,十分优秀!