I am having a problem with retrieving a DateTimeOffset
from a PostgreSQL database using Entity Framework. As far as researching the problem, I found this article that helps me understand what the problem is, but I can't figure out how to fix it.
I have an API that allows users to upload files (mostly images) and it extracts the date that the image was taken and stores it in the database. It works great most of the time. However, if the date is between March 11 to sometime in April (date varies based on year) before 2007 it saves into the database fine but when trying to retrieve the row, it throws the error:
The UTC Offset of the local dateTime parameter does not match the offset argument.
I am using the Timestamp With Time Zone
type in postgreSQL for the CameraDate
field. I can't figure out how to get this to work correctly. If there is a way to do it without changing the database that would be preferable.
Examples:
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
Here is my code:
Context.Files.Add(file);
Context.Entry(file).Reload();
File class looks like this (Some fields removed for briefness):
public class File
{
[Column("FileId")]
public override Guid ID { get; set; }
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public int DisplayId { get; set; }
public DateTimeOffset? CameraDate { get; set; }
}