没有通用的方法' Where' on type' System.Linq.Queryable'与提供的类型参数和参数兼容

时间:2011-11-10 09:04:33

标签: linq iqueryable

我想使用IQueryable检索特定记录。但我得到错误'没有通用方法'哪里' on type' System.Linq.Queryable'与提供的类型参数和参数兼容。如果方法是非泛型的,则不应提供类型参数。'。我得到了所选的行ID,但我无法显示它。这是我的代码。

 internal static IQueryable GetRecordsFromPrimaryKeys(this IQueryable datasource, List<FilterDescriptor> primaryKeys)
    {
        IQueryable data = datasource;

        ParameterExpression paramExp = null;
        bool firstLoop = false;
        System.Linq.Expressions.Expression predicate = null;

        var RecordType = datasource.GetObjectType();
        paramExp = RecordType.Parameter();

        foreach (FilterDescriptor primaryKey in primaryKeys)
        {
            if (!(firstLoop))
            {
                predicate = data.Predicate(paramExp, primaryKey.ColumnName, primaryKey.Value, FilterType.Equals, false, RecordType);
                firstLoop = true;
            }
            else
            {
                predicate = predicate.AndPredicate(data.Predicate(paramExp, primaryKey.ColumnName, primaryKey.Value, FilterType.Equals, false, RecordType));
            }
        }

        if (paramExp != null && predicate != null)
        {
            var lambda = Expression.Lambda(predicate, paramExp);
            data = data.Provider.CreateQuery(
                       Expression.Call(
                       typeof(Queryable),
                       "Where",
                       new Type[] { data.ElementType },
                       data.Expression,
                       lambda
                       )
                   );

        }

        return data;
    }

我的代码适用于IEnumerable / IQueryable / ICollection。但是当我使用关键字virtual指定类并输入ICollection时,它会引发异常。我的代码是

public class RoomType
{
    public int ID { get; set; }

    [MaxLength(10, ErrorMessage = "Room code cannot be longer than 10 characters.")]
    public string Code { get; set; }

    [MaxLength(50, ErrorMessage = "Room name cannot be longer than 50 characters.")]
    public string Name { get; set; }

    public virtual ICollection<RoomCategory> RoomCategories { get; set; }
}

一些随机值会附加到&#39; RecordType&#39;使用关键字&#39; virtual&#39;。我认为这会导致异常。仍在寻找解决方案。

我不知道出了什么问题。欢迎任何建议。

感谢。

2 个答案:

答案 0 :(得分:1)

我刚遇到类似的情况。问题源于这样一个事实:在某些情况下,您处理的是“代理”,而不是实际的实体。因此,您需要确保RecordTypedata.ElementType匹配。

尝试:

var recordType = datasource.GetObjectType();

// make sure we have the correct type (not the proxy)
if (recordType.BaseType.Name != "Object") 
    recordType = recordType.BaseType;

或者更好,请尝试:

var recordType = data.ElementType

答案 1 :(得分:0)

尝试使用typeof(Enumerable)代替typeof(Queryable)