使用 GridView 和 LINQ to SQL 进行分页



My grideview:

<asp:GridView runat="server" ID="MyGridView" AutoGenerateColumns="false" 
    DataKeyNames="ID" 
    OnRowCreated="MyGridView_RowCreated" AllowPaging="true" Width="100%" 
    PageSize="5" onpageindexchanging="MyGridView_PageIndexChanging" >

我在page_load上的代码:

MyGridView.DataSource = new Emp.GetData();
MyGridView.DataBind();

我的代码:

using (DataContext db = new DataContext())
{
    var query = //valid query here   
    query = query.Skip(StartRowIndex *5 ).Take(5);
    return query.ToList();
}
如果我的数据库中有 15 条记录,则在页面加载时,我会看到第 1、2 3 页的链接,其中显示了第 1 页的数据 - 5 条记录。 然后,当我转到包含 2 条记录的第 5 页时,我看到第 1 页和第 3 页

链接。 当我转到第 3 页时,我只看到 2 条记录而不是 5 条,有时分页链接也无法正确显示。

我想每页显示 5 条记录,并希望 GridView 确定要显示的页数。

我没有使用 LinqDataSource,只是有一个返回列表的方法。

如果您确实使用LinqDataSource,实际上会更容易。

<asp:LinqDataSource ID="MyDataSource" runat="server"
    OnSelecting="MyDataSource_Selecting">
</asp:LinqDataSource>

在代码隐藏中,您只需重新路由LinqDataSource即可调用业务逻辑层。 但是,它现在需要使DataContext对象保持打开状态,即不要将其包装在using块中,否则您将收到错误(并且也不要应用带有Skip(..).Take(..)的手动分页。

protected void MyDataSource_Selecting(object sender,
        LinqDataSourceSelectEventArgs e) {
    e.Result = Emp.GetData();
}

现在,LinqDataSource应该自动为您管理所有分页。

或者

,您可以使用PagedDataSource类来实现此目的。

这是一篇解释它如何工作的文章。

相关内容

  • 没有找到相关文章

最新更新