【发布时间】:2011-08-26 22:13:44
【问题描述】:
我的网格视图:
<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,只是有一个返回列表的方法。
【问题讨论】:
-
什么样的LINQ? LINQ to XML?
-
如果我使用 linqdatasource 我会有 maxrecords 并且以某种方式管理分页。使用gridview 大多数时候我没有得到分页链接。如果我设置 take(maxrowcount) 那么它有时会工作......
标签: c# linq linq-to-sql gridview pagination