如何在 PostgreSQL 中存储 DateTimeOffset

How to store DateTimeOffset in PostreSQL

我在使用 Entity Framework 从 PostgreSQL 数据库中检索 DateTimeOffset 时遇到问题。就研究问题而言,我发现 this article 可以帮助我理解问题所在,但我不知道如何解决它。

我有一个 API 允许用户上传文件(主要是图像),它提取图像的拍摄日期并将其存储在数据库中。它大部分时间都很好用。但是,如果日期在 2007 年之前的 3 月 11 日到 4 月的某个时间(日期因年份而异),它可以很好地保存到数据库中,但是在尝试检索该行时,它会抛出错误:

The UTC Offset of the local dateTime parameter does not match the offset argument.

我在 postgreSQL 中为 CameraDate 字段使用 Timestamp With Time Zone 类型。我不知道如何让它正常工作。如果有一种方法可以在不更改数据库的情况下执行此操作,那将是更可取的。

示例:

2001-04-01 10:47:17-06 Works
2001-03-01 10:47:17-06 Works
2001-03-13 10:47:17-06 Doesn't work
2007-03-13 10:47:17-06 Works

这是我的代码:

Context.Files.Add(file);
Context.Entry(file).Reload();

文件 class 看起来像这样(为简洁起见删除了一些字段):

public class File
{
    [Column("FileId")]
    public override Guid ID { get; set; }
    [DatabaseGenerated(DatabaseGeneratedOption.Identity)]
    public int DisplayId { get; set; }
    public DateTimeOffset? CameraDate { get; set; }
}

好的,这似乎是 npgsql 或 npgsql.EntityFramework 中 DateTimeOffset 的错误。似乎记录了其他几个问题 in their issue tracker. In particular issue #542 非常接近 - 但有不同的异常消息。

我建议你在那里创建一个新问题,因为它们最有助于进一步诊断。