gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-30 13:48:17 24 4
gpt4 key购买 nike

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

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com