我正在尝试在 C# 日期时间和 SQL 日期时间之间进行相等性比较,由于存储这些值的精度,这似乎失败了。
假设我有一个非常简单的 SQL 表,其中包含以下字段:
ID (PK, int, not null) - identity
Title (text, null)
UpdateTime (datetime, not null)
我通过 Entity 框架创建一个类对象,将其 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 中的日期时间相同?取回我的 ID 的最佳方法是什么?
最佳答案
如果您使用的是 SQL 服务器,请改用 DateTime2
。它具有与 .NET 类型相同的精度。
关于c# - C# 日期时间和 SQL 日期时间之间的相等性比较失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13057855/