首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在LinqToEntities中将字符串转换为datetime (在查询中)

在LinqToEntities中将字符串转换为datetime (在查询中)
EN

Stack Overflow用户
提问于 2012-02-01 03:10:41
回答 5查看 10.2K关注 0票数 3

我在一个表中有一个字符串格式的日期,我需要将它与参数进行比较,以检索与给定日期匹配的所有行。我该怎么做呢?我不能使用DateTime.Parse和Convert.ToDateTime。这两种方法都不受支持(我得到一个错误)。在Linq中这是可能的吗?或者由于这个限制,我必须为它编写一个存储过程吗?

注意:我不能将列的数据类型从varchar更改为DateTime,因为该列还包含其他值,而不仅仅是日期。它是一个泛型表格,根据其他列中的值,该列可以包含不同类型的值。更改此设计超出了此问题的范围。

示例代码("x“是传入此方法的日期参数):

代码语言:javascript
运行
复制
    from t1 in Table1
    where EntityFunctions.DiffDays(DateTime.Parse(t1.Value),x) == 0
    select new {t1.Col1, t1.Col2};

更新:如果我使用DateTime.Parse,我得到一个错误:"LINQ to Entities无法识别方法'System.DateTime解析(System.String)‘方法,此方法无法转换为存储表达式。“Convert.ToDateTime也有类似的错误。

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2012-02-01 03:17:37

(复制我的评论以粘贴一些示例代码)

如果日期是字符串格式,不能在DateTime上应用ToString (可能是x),然后进行字符串比较吗?

由于您正在处理字符串表示,因此您需要处理几个问题,否则这些问题将由DateTime透明地处理,包括:

  • 日期-时间格式差异(dd/MM/yyyyMM/dd/yyyy).
  • Presence或一位数日和月的前导零不存在(例如01/01/20111/1/2001).
  • Two-digit或四位年份表示法(例如dd/MM/yyyy01/01/11).
  • Timezone偏移量))。例如,2011-01-01 23:30 -01:00的日期实际上应该是2011-01-02.

如果您的所有日期都是美国格式,具有两位数的日和月、四位数的年,并且没有时区偏移,则下面的示例代码将起作用。

代码语言:javascript
运行
复制
from t1 in Table1
where t1.Value.StartsWith(x.ToString(@"MM\/dd\/yyyy"))
select new {t1.Col1, t1.Col2};

编辑:备用解决方案:

如果可以在数据库中定义视图,则可以通过有选择地将VARCHAR转换为DATETIME来绕过此问题。我假设Value是日期列的名称。

代码语言:javascript
运行
复制
SELECT CONVERT(DATE, Value, 101) AS Value, Col1, Col2
FROM Table1
WHERE ISDATE(Value) = 1

然后,在你的LINQ中,做一个简单的DateTime相等检查:

代码语言:javascript
运行
复制
from t1 in Table1
where t1.Value == x.Date
select new {t1.Col1, t1.Col2};
票数 1
EN

Stack Overflow用户

发布于 2012-02-01 06:41:06

这是可行的。你需要一个扩展方法来保证dateTime解析的安全。之后,您可以在Linq查询中使用该方法的结果。它将从表中获取所有行,因此在性能方面,这可能是一个不太理想的(!)解决方案。不过,它回答了这个问题。

代码语言:javascript
运行
复制
    void Main()
    {
         var stringDates = new List<string> { "2011-13-01", "2011-01-12" };

         DateTime paramDate = new DateTime(2011,01,13);

         var q = from stringDate in stringDates
            let realdate = stringDate.SafeParse()
            where realdate == paramDate
            select new { stringDate, realdate };

         q.Dump();
    }


    static class StringDateParseExt
    {
       public static DateTime SafeParse(this string  any)
        {
          DateTime parsedDate;
          DateTime.TryParseExact(any, 
                "yyyy-dd-MM", 
                System.Globalization.CultureInfo.InvariantCulture , 
                System.Globalization.DateTimeStyles.None, 
                out parsedDate);
          return parsedDate;
        }
    }
票数 1
EN

Stack Overflow用户

发布于 2016-04-14 04:45:10

除了@Douglas指出的使用字符串表示的问题之外,您可以使用SqlFunctionsDbFunctions类将Linq中的stringDateTime转换为实体:

代码语言:javascript
运行
复制
DbFunctions.CreateDateTime(SqlFunctions.DatePart("yy", dateString),
                           SqlFunctions.DatePart("mm", dateString),
                           SqlFunctions.DatePart("dd", dateString),
                           SqlFunctions.DatePart("hh", dateString),
                           SqlFunctions.DatePart("mi", dateString),
                           SqlFunctions.DatePart("ss", dateString));
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9085414

复制
相关文章

相似问题

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