首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Linq中的DateTime.Compare

Linq中的DateTime.Compare
EN

Stack Overflow用户
提问于 2013-11-20 15:09:53
回答 1查看 52.2K关注 0票数 5

我正尝试在Linq中使用DateTime.Compare:

代码语言:javascript
运行
复制
from ---  
where DateTime.Compare(Convert.ToDateTime(ktab.KTABTOM), DateTime.Now) < 1
select new 
{
-------
}

但这给了我一个错误:

代码语言:javascript
运行
复制
LINQ to Entities does not recognize the method 'System.DateTime ConvertTimeFromUtc(System.DateTime, System.TimeZoneInfo)' method, and this method cannot be translated into a store expression  

This链接建议我们应该使用EntityFunctions来修复Linq中的dateTime操作。但在这里,我需要比较完整的日期。即使是this也不会帮我。

日期的格式为yyyy-MM-dd。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-11-20 15:57:04

您不需要DateTime.Compare,只需编写ktab.KTABTOM <= DateTime.Now即可

具有可空DateTime的示例:

不编译

代码语言:javascript
运行
复制
from p in Projects
where DateTime.Compare(DateTime.Now, p.EndDate) <= 0
select p.EndDate

代码语言:javascript
运行
复制
from p in Projects
where DateTime.Now <= p.EndDate
select p.EndDate

翻译为

代码语言:javascript
运行
复制
SELECT 
[Extent1].[EndDate] AS [EndDate]
FROM [dbo].[Project] AS [Extent1]
WHERE  CAST( SysDateTime() AS datetime2) <= [Extent1].[EndDate]

不带可空DateTime的示例:

代码语言:javascript
运行
复制
from p in Projects
where DateTime.Compare(DateTime.Now, p.StartDate) <= 0
select p.StartDate

代码语言:javascript
运行
复制
from p in Projects
where DateTime.Now <= p.StartDate
select p.StartDate

两者都转换为

代码语言:javascript
运行
复制
SELECT 
[Extent1].[StartDate] AS [StartDate]
FROM [dbo].[Project] AS [Extent1]
WHERE (SysDateTime()) <= [Extent1].[StartDate]
票数 11
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/20089594

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档