我正在尝试在 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 中的日期时间?拿回我的身份证的最佳方法是什么?