首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
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

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
查看全部 5 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9085414

复制
相关文章

相似问题

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