0

我正在使用一个函数来允许来自 Web UI 的查询组合,并且我将实现分页功能,它将可用于 DataBound 控件,例如 ObjectDataSource、gridView 等:

  public class MyClass<TEntity> where TEntity : class
    {
        FakeEntities xxx = new FakeEntities();

        public  IEnumerable<TEntity> Get(Func<IQueryable<TEntity>, IQueryable<TEntity>> queryExpression)
        {
            var query = xxx.Set<TEntity>();

            return queryExpression(query).ToList();
        }

        public int Count()
        {
            // What Can I return?
        }
    }

// **** USAGE ****
  MyClass<User> u = new MyClass<User>();
            var all = u.Get(p => p.Where(z => z.Account == "Smith").OrderBy(order => order.IdOther).Skip(1).Take(2));

上面的查询使用了 Take 和 Skip 功能,所以我可以得到我的实体的真实数量吗?显然我必须在不修改过滤器表达式的情况下返回查询计数。

4

1 回答 1

0

我找到了这个解决方案:Get count of an IQueryable<T>

但是我得到了带有内部消息的 targetInvocationException {“此方法支持 LINQ to Entities 基础结构,不打算直接从您的代码中使用。”}

我知道我的请求可能是异常的,因为最佳实践应该强制将“演示需求”移动到某个包装类,这就是我要做的。所以我不再需要在我的业务逻辑类上获取 Count 实体。

这只是 UI 问题。

谢谢你一样。

于 2013-05-24T11:32:48.823 回答