繁体   English   中英

使用GridView和LINQ to SQL进行分页

[英]Paging with GridView and LINQ to SQL

我的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条记录。 然后,当我转到具有5条记录的第2页时,我看到了第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(..)应用手动分页Skip(..).Take(..)

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

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

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

这是一篇说明其工作原理的文章

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM