【问题标题】:How to convert a string into a datetime in Linq to Entities query?如何在 Linq to Entities 查询中将字符串转换为日期时间?
【发布时间】:2013-06-25 05:39:18
【问题描述】:

我的 Linq 到实体查询的编写如下。 我的 ORACLE 数据库中 DATECOLUMN1 的数据类型是字符串。

Datetime FilterStartDate = DateTime.Now;
            var query = from c in db.TABLE1
                        join l in db.TABLE2 on c.FK equals l.PK
                        where (FilterStartDate >= DateTime.ParseExact(l.DATECOLUMN1, "dd/MM/yyyy", CultureInfo.InvariantCulture) : false) == true
                        select c;

写上面的查询给我一个不支持的错误。如何将 DATECOLUMN1 转换为日期时间进行比较。

附:我无法控制数据库架构,因此更改 Oracle 数据库中列的数据类型对我来说不是一个可行的解决方案。

【问题讨论】:

  • 它是 dd/MM/yyyy 格式

标签: oracle entity-framework linq-to-entities


【解决方案1】:

在您的模型中,将以下属性添加到您的部分类TABLE2

public DateTime DATECOLUMN1_NEW
{
    get
    {           
        return  DateTime.ParseExact(DATECOLUMN1, "dd/MM/yyyy", CultureInfo.InvariantCulture);
    }

    set { }
}

然后,在您的 LINQ 查询中,使用 DATECOLUMN1_NEW(它已经是 DateTime 格式)代替 DATECOLUMN1

【讨论】:

  • 谢谢,这就是诀窍。最近,我意识到在 L2E 中没有直接的方法可以将字符串转换为日期时间...谢谢
【解决方案2】:

Erm.. 我认为您遇到的问题是您将“:false”放在那里。

您似乎正在尝试使用条件运算符 (?:),但您忘记了“?”。

我认为您实际上并不需要这个,因为您只是想确定日期是否更大。此外,如果 ParseExact 失败,它将引发异常(不是您想要的),因此您应该改用 TryParse 并处理返回的真/假和输出值以确定日期是否为 (a) 实际上是日期 (b) 少然后是 FilterStartDate。

您可以使用两种选择:

  1. 在此处使用答案中描述的功能:How to I use TryParse in a linq query of xml data?

  2. 使用以下我认为更易读的流畅语法版本。

    var query = db.Table1.Join(db.Table2, x => x.FK, y => y.PK, (x, y) => x).Where(x => { 日期时间结果; DateTime.TryParse(x.Date, out Result); return DateTime.TryParse(x.Date, out Result) && FilterStartDate >= Result; });

【讨论】:

    猜你喜欢
    • 2011-12-21
    • 1970-01-01
    • 1970-01-01
    • 2013-02-28
    • 2011-11-16
    • 1970-01-01
    • 1970-01-01
    • 2012-10-11
    • 1970-01-01
    相关资源
    最近更新 更多