English versionEnglish
杨涛的个人主页

MvcPager分页控件

MvcPager分页示例—使用分页存储过程

本示例演示如何使用分页存储过程获取当前页数据,通过构造函数创建PagedList<T>对象并实现分页。

订单编号订单日期顾客编号收货地址
109401998/3/11 0:00:00BONAP12, rue des Bouchers
109411998/3/11 0:00:00SAVEA187 Suffolk Ln.
109421998/3/11 0:00:00REGGCStrada Provinciale 124
109431998/3/11 0:00:00BSBEVFauntleroy Circus
109441998/3/12 0:00:00BOTTM23 Tsawassen Blvd.
109451998/3/12 0:00:00MORGKHeerstr. 22
109461998/3/12 0:00:00VAFFESmagsloget 45
109471998/3/13 0:00:00BSBEVFauntleroy Circus
109481998/3/13 0:00:00GODOSC/ Romero, 33
109491998/3/13 0:00:00BOTTM23 Tsawassen Blvd.
109501998/3/16 0:00:00MAGAAVia Ludovico il Moro 22
109511998/3/16 0:00:00RICSUStarenweg 5
109521998/3/16 0:00:00ALFKIObere Str. 57
109531998/3/16 0:00:00AROUTBrook Farm Stratford St. Mary
109541998/3/17 0:00:00LINODAve. 5 de Mayo Porlamar
109551998/3/17 0:00:00FOLKOÅkergatan 24
109561998/3/17 0:00:00BLAUSForsterstr. 57
109571998/3/18 0:00:00HILAACarrera 22 con Ave. Carlos Soublette #8-35
109581998/3/18 0:00:00OCEANIng. Gustavo Moncada 8585 Piso 20-A
109591998/3/18 0:00:00GOURLAv. Brasil, 442
首页  上一页  ...  2  3  4  5  6  7  8  9  10  11  12  13  14  15  16  下一页  尾页
<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" 
Inherits="System.Web.Mvc.ViewPage<PagedList<MvcPagerSample.Models.Order>>" %>
<%@ Import Namespace="MvcPagerSample.Models" %>
<%@ Import Namespace="Webdiyer.WebControls.Mvc" %>

<asp:Content ID="Content1" ContentPlaceHolderID="TitleContent" runat="server">
	MvcPager分页示例—使用分页存储过程
</asp:Content>

<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">

    <h2>MvcPager分页示例—使用分页存储过程</h2>
    <div>本示例演示如何使用分页存储过程获取当前页数据,
    通过构造函数创建PagedList<T>对象并实现分页。</div><br />

<table width="98%">
<tr><th>订单编号</th><th>订单日期</th><th>顾客编号</th><th>收货地址</th></tr>
<%foreach(Order od in Model)
 {
     %>
     <tr><td><%=od.OrderID %></td><td><%=od.OrderDate.ToString() %></td>
     <td><%=od.CustomerID %></td><td><%=od.ShipAddress %></td></tr>
     <%
 } %>
</table>
 <%=Html.Pager(Model, new PagerOptions { PageIndexParameterName = "id",
 NumericPagerItemCount=15})%>
</asp:Content>    
    
Create PROCEDURE P_GetPagedOrders2005
(@startIndex INT, 
 @endindex INT
 )
AS
begin
WITH orderList AS ( 
SELECT ROW_NUMBER() OVER (ORDER BY O.orderid DESC)AS Row, O.*
from orders O)

SELECT * FROM orderlist
WHERE Row between @startIndex and @endIndex

end    
    
/// <summary>
/// 使用存储过程获取分页数据示例
/// </summary>
/// <param name="id">当前页索引</param>
/// <returns></returns>
public ActionResult StoredProcedure(int? id)
{
    using (var db = new MvcPagerSampleDataContext())
    {
	//起始记录索引
	int startIndex = id.HasValue&&id.Value>1 ? (id.Value-1)*20+1:0;
	//通过分页存储过程获取当前页的数据
	List<Order> orders = db.GetPagedOrders(startIndex,startIndex+20).ToList();
	//要分页的数据总数
	int totalOrders = db.Orders.Count();
	//用构造函数创建PagedList<T>对象
	PagedList<Order> pagedOrders = new PagedList<Order>(orders, id ?? 1, 20, totalOrders);
	return View(pagedOrders);
    }
}