使用GridView和LINQ to SQL进行分页

时间:2011-05-17 03:34:12

标签: c# linq linq-to-sql gridview pagination

我的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,只是有一个返回列表的方法。

2 个答案:

答案 0 :(得分:4)

如果您使用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应该自动为您管理所有分页。

答案 1 :(得分:0)

或者,您可以使用PagedDataSource class来实现此目的。

Here's an article解释它是如何运作的。