0

最初,我从我的控制器调用了我的 Web 服务中的一个函数,然后我对结果进行分页以仅在我的视图中显示 10 个项目。我是这样进行的:

控制器:

    public ActionResult Index(int? page)
    {
        var companies = _requestServiceClient.GetCompanies();
        int currentPageIndex = page.HasValue ? page.Value - 1 : 0;
        var companiesListPaged = companies.ToPagedList(currentPageIndex, defaultPageSize);
        return View(companiesListPaged);
    }

服务:

    public IEnumerable<Company> GetCompanies()
    {
        using (var unitOfWork = UnitOfWorkFactory.Create())
        {
            var companyRepository = unitOfWork.Create<Company>();
            return companyRepository.GetAll().MyInclude(x => x.City).ToList();
        }
    }

因此,在从我的服务中检索到所有数据后,分页就完成了。它可以工作,但是传输了很多数据,因此效率不高。我更改了代码以直接在服务中执行分页工作,如下所示:

控制器:

    [Authorize]
    public ActionResult Index(int? page)
    {
        int currentPageIndex = page.HasValue ? page.Value - 1 : 0;
        var companies = _requestServiceClient.GetCompaniesToPagedList(currentPageIndex, defaultPageSize);
        return View(companies);
    }

服务:

    public IPagedList<Company> GetCompaniesToPagedList(int PageIndex, int PageSize)
    {
        using (var unitOfWork = UnitOfWorkFactory.Create())
        {
            var companyRepository = unitOfWork.Create<Company>();
            var companies = companyRepository.GetAll().MyInclude(x => x.City).ToList();
            return companies.ToPagedList(PageIndex, PageSize);
        }
    }

它编译但在运行时我得到了错误:

底层连接已关闭:服务器关闭了预期保持活动状态的连接。

任何想法?为什么我的代码中的这种更改会给我这个错误?

我没有改变其他任何东西。

谢谢。


更新

这是 IPagedList 的代码

public interface IPagedList<T> : IList<T>
{
    int PageCount { get; }
    int TotalItemCount { get; }
    int PageIndex { get; }
    int PageNumber { get; }
    int PageSize { get; }
    bool HasPreviousPage { get; }
    bool HasNextPage { get; }
    bool IsFirstPage { get; }
    bool IsLastPage { get; }
}

对于 ToPagedList

    public static IPagedList<T> ToPagedList<T>(this IEnumerable<T> source, int pageIndex, int pageSize, int? totalCount = null)
    {
        return new PagedList<T>(source, pageIndex, pageSize, totalCount);
    }
4

1 回答 1

0

我建议检查调用返回的数据量是否可能超过 Binding 的 ReaderQuotas 元素中定义的限制。

于 2012-04-11T09:28:48.667 回答