我在一个表中有一个字符串格式的日期,我需要将它与参数进行比较,以检索与给定日期匹配的所有行。我该怎么做呢?我不能使用DateTime.Parse和Convert.ToDateTime。这两种方法都不受支持(我得到一个错误)。在Linq中这是可能的吗?或者由于这个限制,我必须为它编写一个存储过程吗?
注意:我不能将列的数据类型从varchar更改为DateTime,因为该列还包含其他值,而不仅仅是日期。它是一个泛型表格,根据其他列中的值,该列可以包含不同类型的值。更改此设计超出了此问题的范围。
示例代码("x“是传入此方法的日期参数):
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也有类似的错误。
发布于 2012-02-01 06:41:06
这是可行的。你需要一个扩展方法来保证dateTime解析的安全。之后,您可以在Linq查询中使用该方法的结果。它将从表中获取所有行,因此在性能方面,这可能是一个不太理想的(!)解决方案。不过,它回答了这个问题。
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;
}
}https://stackoverflow.com/questions/9085414
复制相似问题