我在一个表中有一个字符串格式的日期,我需要将它与参数进行比较,以检索与给定日期匹配的所有行。我该怎么做呢?我不能使用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 03:17:37
(复制我的评论以粘贴一些示例代码)
如果日期是字符串格式,不能在DateTime上应用ToString (可能是x),然后进行字符串比较吗?
由于您正在处理字符串表示,因此您需要处理几个问题,否则这些问题将由DateTime透明地处理,包括:
dd/MM/yyyy与MM/dd/yyyy).01/01/2011与1/1/2001).dd/MM/yyyy与01/01/11).2011-01-01 23:30 -01:00的日期实际上应该是2011-01-02.如果您的所有日期都是美国格式,具有两位数的日和月、四位数的年,并且没有时区偏移,则下面的示例代码将起作用。
from t1 in Table1
where t1.Value.StartsWith(x.ToString(@"MM\/dd\/yyyy"))
select new {t1.Col1, t1.Col2};编辑:备用解决方案:
如果可以在数据库中定义视图,则可以通过有选择地将VARCHAR转换为DATETIME来绕过此问题。我假设Value是日期列的名称。
SELECT CONVERT(DATE, Value, 101) AS Value, Col1, Col2
FROM Table1
WHERE ISDATE(Value) = 1然后,在你的LINQ中,做一个简单的DateTime相等检查:
from t1 in Table1
where t1.Value == x.Date
select new {t1.Col1, t1.Col2};发布于 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;
}
}发布于 2016-04-14 04:45:10
除了@Douglas指出的使用字符串表示的问题之外,您可以使用SqlFunctions和DbFunctions类将Linq中的string到DateTime转换为实体:
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));https://stackoverflow.com/questions/9085414
复制相似问题