public static Iqueryable Join(this Iqueryable outer,IEnumerable inner,string outerSelector,string innerSelector,string resultsSelector,params object[] values){ if (inner == null) throw new ArgumentNullException("inner"); if (outerSelector == null) throw new ArgumentNullException("outerSelector"); if (innerSelector == null) throw new ArgumentNullException("innerSelector"); if (resultsSelector == null) throw new ArgumentNullException("resultsSelctor"); LambdaExpression outerSelectorLambda = DynamicExpression.ParseLambda(outer.ElementType,null,outerSelector,values); LambdaExpression innerSelectorLambda = DynamicExpression.ParseLambda(inner.Asqueryable().ElementType,innerSelector,values); ParameterExpression[] parameters = new ParameterExpression[] { Expression.Parameter(outer.ElementType,"outer"),Expression.Parameter(inner.Asqueryable().ElementType,"inner") }; LambdaExpression resultsSelectorLambda = DynamicExpression.ParseLambda(parameters,resultsSelector,values); return outer.ProvIDer.createquery( Expression.Call( typeof(queryable),"Join",new Type[] { outer.ElementType,inner.Asqueryable().ElementType,outerSelectorLambda.Body.Type,innerSelectorLambda.Body.Type,resultsSelectorLambda.Body.Type },outer.Expression,inner.Asqueryable().Expression,Expression.Quote(outerSelectorLambda),Expression.Quote(innerSelectorLambda),Expression.Quote(resultsSelectorLambda)) );}解决方法 我现在已经修好了将createquery(…)调用的参数传给过多的一个小学生错误.将以下代码粘贴到Dynamicqueryable类中的Dynamic.cs文件中,以进行动态连接扩展方法.您可以在 http://code.msdn.microsoft.com/csharpsamples找到Dynamicquery示例项目的源代码.
请享用.
public static Iqueryable Join(this Iqueryable outer,params object[] values) { if (inner == null) throw new ArgumentNullException("inner"); if (outerSelector == null) throw new ArgumentNullException("outerSelector"); if (innerSelector == null) throw new ArgumentNullException("innerSelector"); if (resultsSelector == null) throw new ArgumentNullException("resultsSelctor"); LambdaExpression outerSelectorLambda = DynamicExpression.ParseLambda(outer.ElementType,values); LambdaExpression innerSelectorLambda = DynamicExpression.ParseLambda(inner.Asqueryable().ElementType,values); ParameterExpression[] parameters = new ParameterExpression[] { Expression.Parameter(outer.ElementType,"inner") }; LambdaExpression resultsSelectorLambda = DynamicExpression.ParseLambda(parameters,values); return outer.ProvIDer.createquery( Expression.Call( typeof(queryable),new Type[] {outer.ElementType,resultsSelectorLambda.Body.Type },Expression.Quote(resultsSelectorLambda))); } //The generic overload. public static Iqueryable<T> Join<T>(this Iqueryable<T> outer,IEnumerable<T> inner,params object[] values) { return (Iqueryable<T>)Join((Iqueryable)outer,(IEnumerable)inner,values); }总结
以上是内存溢出为你收集整理的如何创建一个动态LINQ连接扩展方法全部内容,希望文章能够帮你解决如何创建一个动态LINQ连接扩展方法所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)