我正在尝试编写动态linq查询,如:
var q = obj.Where("message.Contains('hello')");
我知道它适用于
var q = obj.Where(o => o.message.Contains('hello'));
但我正在寻找动态的linq解决方案
感谢。
答案 0 :(得分:12)
现在找到我的答案。
var q = obj.Where("message.Contains(@0)", "hello");
答案 1 :(得分:1)
我知道这不是你想要的,但是要考虑一点:
根据您希望执行的各种操作的数量,我会创建一个switch语句来处理这个问题。
作为一个例子,一些使用枚举的伪代码:
(如果需要,OperationType是枚举)
private object example(OperationType optype, Object obj, String match)
{
var q;
switch (optype)
{
case OperationType.Contains:
q = obj.Where(o => o.message.Contains(match));
break;
case OperationType.EndsWith:
q = obj.Where(o => o.message.EndsWith(match));
break;
case OperationType.StartsWith:
q = obj.Where(o => o.message.StartsWith(match));
break;
}
return q;
}