编译Linq和String.Contains

RuS*_*uSh 3 .net linq linq-to-sql

我正在使用Linq-to-SQL,我使用编译的Linq来获得更好的性能.

我有一个INT名为"LookingFor"字段的用户表,它可以具有以下值:1,2,3,12,123,13,23.

我写了一个查询,根据"lookingFor"列返回用户,我想返回包含"lookingFor"值的所有用户(不仅仅是那些等于它的用户).

在示例if user.LookingFor = 12和query参数中1,应该选择此用户.

private static Func<NeDataContext, int, IQueryable<int>>
      MainSearchQuery = CompiledQuery.Compile((NeDataContext db, int lookingFor) =>
         (from u in db.Users
          where (lookingFor == -1 ? true : u.LookingFor.ToString().Contains(lookingFor)                         
    select u.username);
Run Code Online (Sandbox Code Playgroud)

这个工作在非编译的linq上,但在使用编译时抛出错误.如何使用编译的Linq修复它?

我收到此错误:

String.Contains方法仅支持可在客户端上计算的参数.

小智 8

我面临着同样的问题.我现在已经管理了这个问题的一个解决方法.而不是使用

u.LookingFor.ToString().Contains(lookingFor)
Run Code Online (Sandbox Code Playgroud)

我用过

u.LookingFor.ToString().IndexOf(lookingFor) >= 0
Run Code Online (Sandbox Code Playgroud)