动态LINQ where查询
本文关键字:查询 where LINQ 动态 | 更新日期: 2023-09-27 18:27:00
我使用动态LINQ从用户为给定搜索选择的给定列中创建查询。
例如简化代码,例如
var counter = 0;
var predicate = string.Empty;
foreach(var field in selectedFields)
{
predicate += field + ".Contains(@" + counter + ") ||";
// logical OR, without it the SQL generates AND
}
predicate = predicate.Remove(predicate.LastIndexOf("||", 2));
query = query.Where(predicate, searchvalues);
此代码生成给定的SQL查询
(([t0].[Field1] LIKE 'searchstring') OR ([t0].[Field2] LIKE 'searchstring'))
这是正确的,尽管我想做的是能够使用通配符,当我尝试输入一个百分比字符时,生成的SQL是
(([t0].[field1] LIKE 'searchstring' ESCAPE '~') OR ([t0].[field2] LIKE 'searchstring' ESCAPE '~'))
在使用动态L2S时,有没有办法在搜索字符串中使用通配符?
问候
您可以尝试使用.StartsWith || .EndsWith || .Contains
这可能会解决问题。
由于使用的是Linq到Sql,因此可以使用SqlMethods辅助类。
其中一个方法是Like,它映射到SQLLIKE子句上。如果您需要它,它比使用.StartsWith
等更灵活