3

我正在尝试在 C# 日期时间和 SQL 日期时间之间进行相等比较,由于这些值的存储精度,这似乎失败了。

假设我有一个非常简单的 SQL 表,其中包含以下字段:

ID (PK, int, not null) - identity
Title (text, null)
UpdateTime (datetime, not null)

我通过实体框架创建了一个类对象,将其 UpdateTime 设置为 DateTime.Now,如下所示:

DateTime now = DateTime.Now;
Title.UpdateTime = now;

当我将新对象插入表中时,我看到所有值似乎都已正确存储。现在我想要为我的对象创建的 ID。

这就是事情变得无聊的地方。我尝试通过 LINQ 拉回 ID:

Title.ID = context.DBTitles.Where(x=>x.UpdateTime == now).FirstOrDefault().ID;

这会引发异常,因为查询返回 null,尽管我插入的“现在”应该与插入到表中的“现在”相同。

所以我的问题是:如何确保我的 C# 日期时间等同于存储在 SQL 中的日期时间?拿回我的身份证的最佳方法是什么?

4

2 回答 2

6

如果您使用的是 SQL 服务器,请DateTime2改用。它具有与 .NET 类型相同的精度。

于 2012-10-24T21:16:56.167 回答
3

如果您使用的是 Linq,您插入的对象不会在提交时获得分配给它的 ID 吗?你不需要“召回”它。

于 2012-10-24T21:17:23.060 回答