任何人都可以告诉我以下内容有什么问题,以及如何解决它:
[Export("DoneAction")]
private void DoneAction()
{
Console.WriteLine("Your Action!");
}
上述目的是仅获取 //filterItem.Value is a string array - It is being conerted into an int array
var intFilters = Array.ConvertAll(filterItem.Value, s => int.Parse(s));
//Returns an IQueryable<int> for all items in this context that are also in intFilters
var ids = Context.table1.Where(a => intFilters.Any(y => y == a.domId)).Select(x => x.domId);
//query is an IQueryable
query = query.Where(x => specUnidsNullable.Contains(y => y == x.Id));
query
的记录
我收到以下错误:
ids
我也试过这个:
Cannot convert lambda expression to type int because it is not a delegate type
哪个工作正常 - 我这样做的原因是看问题是var ids = idsNullable.Where(x => x > 0);
无法转换为lambda类型表达式。
关于这个错误有很多问题,但似乎没有一个问题可以解决我能看到的特定问题......
答案 0 :(得分:2)
specUnidsNullable.Contains(y => y == x.Id)
调用LINQ Contains
方法,该方法需要给定类型的单个值(在这种情况下我假设为int
),并且您在那里传递表达式。所以改为
specUnidsNullable.Contains(x.Id);
或
specUnidsNullable.Any(y => y == x.Id);
答案 1 :(得分:0)
我相信在您安装 EntityFramework 并使用 System.Data.Entity.QueryableExtensions 添加后,您的问题将得到解决。