繁体   English   中英

如何在Linq谓词中查询datetime文字和空值?

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM