c# - C# 日期时间和 SQL 日期时间之间的相等性比较失败

标签 c# sql-server-2008 datetime linq-to-entities equality

我正在尝试在 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/

相关文章:

php - 用PHP将日期和时间写入LOG文件

c# - 如果日期时间是另一个日期时间的 24 小时,则返回

c# - 转换为字符串时精度下降到 3 位大数字

sql - 将 XML 存储在 XML 类型字段中或使用 FILESTREAM

c# - 如何用 MVC ActionFilter(或其他东西)替换基本 Controller ?

c# - SQL Server : cannot connect from local website (SQL Network Interfaces, 错误:26 - 定位指定的服务器/实例时出错)

sql-server - 使用 TOP 子句在同一事务中选择和删除

python - 如何为日期时间设置 UTC 偏移量?

c# - 在用户提供时获取代码中的 Windows 特殊文件夹

c# - 如何让 CLR 知道从 GAC 选择哪个程序集?