最近正在學習Linq,看到分頁這裡的時候感覺真的很簡單,可是又擔心學着學習就把知識混在一起,不知道大家在剛學的時候是不是跟我一樣,因為他有的地主真的太像SQL了
分頁方式:
擷取資料總條數: var Count = db.XXX.Count(); 如果要是以往的寫法還得寫 select count(*) from XXXX; 還得調用SQLHelper.cs類裡面的方法才行,現在就這麼一句話就搞定…… 汗額..
再使用Skip()和Take()方法進行分頁
說明,引用至李永京部落格想學Linq去他部落格吧:
<a href="http://www.cnblogs.com/lyj/">http://www.cnblogs.com/lyj/</a>
說明:Skip()跳過集合的前n個元素;延遲。即我們跳過給定的數目傳回後面的結果集。
說明:Take()擷取集合的前n個元素;延遲。即隻傳回限定數量的結果集。
<a href="http://www.cnblogs.com/lyj/"></a>
下面就把代碼貼出來
Aspx頁面代碼片段:隻有一個GridView和一個AspNetPager控件,沒有其他的代碼;
<div>
<asp:GridView ID="GridView1" runat="server">
</asp:GridView>
<webdiyer:AspNetPager ID="AspNetPager1" runat="server" OnPageChanged="AspNetPager1_PageChanged"
PageSize="15" UrlPaging="True">
</webdiyer:AspNetPager>
</div>
背景代碼:
var Count = db.InBill.Count();
AspNetPager1.RecordCount = Count;
var paging = (from i in db.InBill
orderby i.InDate descending
select i).Skip(AspNetPager1.StartRecordIndex - 1).Take(AspNetPager1.PageSize); //索引方式:分頁操作;
GridView1.DataSource = paging;
GridView1.DataBind();