标签:entity-framework-5 linq c entity-framework lambda
我想创建这样的lambda
user => user.Address == address
但是还没有编译一个,我想返回LambdaExpression
如果lambda像这样恒定
user => user.Age == 50
那我可以用这种方法
public static LambdaExpression PropertyEqual(Type tEntityType, string propertyName, object value)
{
// entity => entity.PropName == const
var itemParameter = Expression.Parameter(tEntityType, "entity");
return Expression.Lambda
(
Expression.Equal
(
Expression.Property
(
itemParameter,
propertyName
),
Expression.Constant(value) // Tried to replace this with Expression.Parameter or Expression.Variable but no luck
),
new[] { itemParameter }
);
}
如何使此方法接受变量地址来自lambda表达式之外的范围?
var addressPropertyName = "Address";
var address = new Address() {...};
var q = Repo.GetQuery().Where(PropertyEqual(typeof(User), addressPropertyName, address))
编辑:澄清我的问题:如何构建正确的表达式以生成第一个lambda?
更新:这是不可能的,因为EF does not support non-scalar variable
我将lambda更改为user => user.AddressId == addressId,如建议的here.只是如何从已知的导航属性Address获取AddressId FK PropertyInfo.
解决方法:
您不能在变量上动态生成闭包(您不能将变量的生存期延长至其上下文之外),因为这是编译器的窍门(重写代码可以做到这一点).
如果您不希望使用闭包,但需要其他参数,则可以在表达式中添加其他参数.
你可以
Expression<Func<string>> myExpr = () => address;
现在,您的地址附近有一个表达式.现在,您只需要组合两个表达式即可.
您必须将方法更改为:
public static LambdaExpression PropertyEqual<T>(Type tEntityType, string propertyName, Expression<Func<T>> getValue)
{
// entity => entity.PropName == const
var itemParameter = Expression.Parameter(tEntityType, "entity");
return Expression.Lambda
(
Expression.Equal
(
Expression.Property
(
itemParameter,
propertyName
),
Expression.Invoke(getValue) // You could directly use getValue.Body instead of Expression.Invoke(getValue)
),
new[] { itemParameter }
);
}
标签:entity-framework-5,linq,c,entity-framework,lambda 来源: https://codeday.me/bug/20191030/1969059.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。