[英]How to query datetime literals and null values in Linq predicate?
在我当前的查询中,我遇到如下错误:
The datetime literal value '2012-05-24' is not valid.
对于常规linq查询,它看起来像这样:
_listHistory = (from item in dbase.histories
where item.UserID == details.UserID && item.FriendID.HasValue == true && item.LogDate < today
select item).OrderByDescending(x => x.LogDate).Take(take).Skip(skip).ToList();
我将处理表“ Columns
”的数量,所以我必须使用linq谓词:
string predicate = string.Format("it.UserID=={0} && CAST(it.{1} as Edm.Int64) != null && it.LogDate <= DATETIME'{2}'",
details.UserID, columnname, string.Format("{0:yyyy-MM-dd}", today));
_listHistory = dbase.histories.Where(predicate)
.OrderByDescending(x => x.LogDate).Take(take).Skip(skip).ToList();
但是这个查询会导致上面的错误。 任何人都可以帮我构建我的linq查询吗?
这是我第一次处理Linq谓词和文字。
您可能会使用动态LINQ支持 ,但假设这是实体查询语言,您可以通过调用CreateDateTime构建日期时间:
http://msdn.microsoft.com/en-us/library/bb738563.aspx
CreateDateTime( year, month, day, hour, minute, second)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.