天天看點

Linq配合AspNetPager高效分頁

最近正在學習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控件,沒有其他的代碼;

&lt;div&gt;

        &lt;asp:GridView ID="GridView1" runat="server"&gt;

        &lt;/asp:GridView&gt;

        &lt;webdiyer:AspNetPager ID="AspNetPager1" runat="server" OnPageChanged="AspNetPager1_PageChanged"

            PageSize="15" UrlPaging="True"&gt;

        &lt;/webdiyer:AspNetPager&gt;

     &lt;/div&gt; 

背景代碼:

            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();