我的EFService中的代码:
private IDbSet<Item> _Items;
private int _SearchTakeCount = 10;
public IList<string> SearchByArticleCount(int articleCount)
{
return _Items.AsNoTracking().Where(m => m.Articles.Count().Equals(articleCount))
.Take(_SearchTakeCount)
.Select(m => m.Articles.Count().ToString())
.Distinct()
.ToList();
}我的主计长中的代码:
public virtual ActionResult AutoCompleteSearch(string term, KeywordSearchBy searchBy = KeywordSearchBy.Name)
{
IList<string> data = new List<string>();
switch (searchBy)
{
case ItemSearchBy.Name:
data = _ItemService.SearchByName(term);
break;
case ItemSearchBy.ArticleCount:
int articleCount = Convert.ToInt32(term);
data = _ItemService.SearchByArticleCount(articleCount);
break;
}当我运行该项目时,异常会被发现。这个例外情况是: LINQ不识别方法'System.String ToString()‘方法,并且该方法不能转换为存储表达式。
发布于 2014-05-25 06:52:36
在完成EF部件之后,将ToString()调用作为LINQ查询:
public IList<string> SearchByArticleCount(int articleCount)
{
return _Items.AsNoTracking().Where(m => m.Articles.Count().Equals(articleCount))
.Take(_SearchTakeCount)
.Select(m => m.Articles.Count())
.Distinct()
.AsEnumerable()
.Select(x => x.ToString())
.ToList();
}https://stackoverflow.com/questions/23852785
复制相似问题