我遇到了一些我的Entity Framework实体无法保存数据的问题。我得到的错误是
The conversion of a datetime2 data type to a datetime data type resulted in an out-of-range value
我有一张名为“Notes”的表。它有一个名为“NoteDateTime”的日期时间字段。这是用于创建表的SQL的片段。正如您所看到的,NoteDateTime字段没有任何异常。
CREATE TABLE [db].[Notes](
[NoteID] [int] IDENTITY(1,1) NOT NULL,
[NoteText] [varchar](8000) NULL,
[NoteDateTime] [datetime] NULL,
[IsReviewRequired] [bit] NULL,
[ConvertToGlobal] [bit] NULL,
[EmployeeID] [int] NULL,
[EvaluationID] [int] NULL,
[CustomerID] [int] NULL,
[EmailID] [int] NULL,
[AddedWhenMerged] [bit] NULL,
CONSTRAINT [PK_Notes] PRIMARY KEY CLUSTERED
(
[NoteID] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]
GO
在我的C#代码中,我填充了一个“Notes”实体并调用了SaveChanges()方法。当我调用SaveChanges()时会发生错误。
dbContext.Notes.Add(new Note
{
EvaluationID = evaluationId,
CustomerID = customerId,
EmployeeID = employeeId,
NoteDateTime = DateTime.Now,
NoteText = noteText,
});
dbContext.SaveChanges();
我已经阅读了几个stackoverflow线程,建议是确保使用正确的日期并且日期不应为null。日期不为空,它肯定在可接受的最小/最大限制范围内。我也尝试将列的类型转换为数据库中的datetime2,但这并没有解决问题。奇怪的是,这似乎是最近的一个问题。在我们的环境中,我唯一能想到的就是我们将项目迁移到使用MVC 4。
如何解决此问题并使我的Note实体正确保存?
答案 0 :(得分:1)
Julia Lehrman在这里讨论了这个问题(http://channel9.msdn.com/Shows/Visual-Studio-Toolbox/Entity-Framework-Tips-and-Tricks),相信我,她是专家。
我自己,我会在你的代码中使[Note DateTime]可以像这样
public DateTime? NoteDateTime { set; get; }
答案 1 :(得分:0)
如您未提及,请使用Sql Profiler查看发送到服务器的SQL。尝试手动运行sql并查看返回的错误。