Func<TObject, bool>是委托(delegate)
Expression<Func<TObject, bool>>是表达式
Expression编译后就会变成delegate,才能运行。比如
Expression<Func<int, bool>> ex = x=>x < 100;
Func<int, bool> func = ex.Compile();
然后你就可以调用func:
func(5) //-返回 true
func(200) //- 返回 false
而表达式是不能直接调用的。
参考:http://stackoverflow.com/questions/793571/why-would-you-use-expressionfunct-rather-than-funct
关于EF中用哪个你可以看看这篇文章:Entity Framework - Func引起的数据库全表查询
关于如何将多个expression合并为一个可以写多个where:
.where(expression1).where(expression2)...
运行时EF会自动合并优化的
Func<TObject, bool> 是 一个参数为 TObject 类型的参数 返回值为bool 类型的匿名函数 eg:
Func<string, bool> func = delegate(string s) {
return true;
};
如何将多个Expression合并为一个呢?
ParameterExpression paraLeft = Expression.Parameter(typeof(int), "a");
ParameterExpression paraRight = Expression.Parameter(typeof(int), "b");
BinaryExpression binaryLeft = Expression.Multiply(paraLeft, paraRight);
ConstantExpression conRight = Expression.Constant(2, typeof(int));
BinaryExpression binaryBody = Expression.Add(binaryLeft, conRight);
Expression<Func<int, int, int>> lambda =
Expression.Lambda<Func<int, int, int>>(binaryBody, paraLeft, paraRight);
Func<int, int, int> myLambda = lambda.Compile();
int result = myLambda(2, 3);
仅供参考
Func和Expresion<Func>可以说是类似的,不过,他们有个本质的区别:
在查询里使用EXPRESSION会适当的生成到SQL语句中,而Func则不会。
至于如何构建一个Expression,如果只是简单的,那么直接使用Func替代(也可以直接强制转换,默认下,对简单的,可以SQL语句实现的表达式会当作Expression,否则当作Func)
其它的构造方式,参考:
Expression,如果只是简单的,那么直接使用Func替代(也可以直接强制转换,默认下,对简单的,可以SQL语句实现的表达式会当作Expression,否则当作