`
yake2011
  • 浏览: 18236 次
最近访客 更多访客>>
社区版块
存档分类
最新评论

ASP.NET分页之自定义存储过程分页(真分页)

阅读更多
原文链接

 

本文来自 CSDN 博客 作者:Cici Cheng

 

在前三节中探讨了假分页,假分页最大的弊端就是从数据库服务器取出了很多数据,却只是显示其中的一小部分,以此为例,每次页面加载时,IIS服务器都会从SQLSERVER数据库服务器提取3144条数据,而实际上却只有10条呈现给了用户,这样极大的浪费了服务器资源。从这一节开始我们来探讨真分页,真分页也就是只取需要显示的数据,比如每页显示10条,那就只从数据库服务器取出10条,然后予以呈现,这样就极大的节约了系统资源,这种分页在当今IT市场上极为通用的一种用法。

要达到此目的,就需要先获取当前查询条件下能获取的总的数据条数,然后再告诉服务器我要去那条到那条,也就是开始行的索引(startIndex)和结束行的索引(endIndex),在SQLSERVER数据库中无法动态设定行号(也就是数据行的索引)的取值范围,所以这里就必须要使用存储过程或者自定义函数。而在ORACLE数据库中有一个伪列的概念,即ROWNUM,其实也就是查询结果集数据行的索引,所以在ORACLE中只通过查询语句便可实现真分页。

在SQLSERVER 2005中提供了一个在2000中没有的函数 -- -- row_number(),这个函数可以获取数据结果集行的索引。

1)在SQLSERVER中处理分页,必须使用存储过程或自定义函数

 

--通过开始行和结束行的索引获取结果集的存储过程

create procedure sp_Paging_GetCounty

@startIndex int,

@endIndex int

as

with table_temp as (select row_number() over(order by o_id) as rowIndex,* from County)

select * from table_temp where rowIndex between @startIndex and @endIndex

go

 

 

--通过开始行和结束行的索引获取结果集的函数

create function ft_Paging_GetCounty(@startIndex int,@endIndex int)

returns table

as

return(with table_temp as (select row_number() over(order by o_id) as rowIndex,* from County)

select * from table_temp where rowIndex between @startIndex and @endIndex)

go

 

 

--获取所有符合查询条件的结果集的总行数

select count(*) from County

 

 

执行以下操作时

 

exec sp_Paging_GetCounty 1,12

select * from ft_Paging_GetCounty(1,5)

select count(*) from County

 

 

测试结果如下:

 



 

2)在ORACLE中处理分页则相对简单,只需要两个查询即可

 

 

 

--通过开始行和结束行的索引获取结果集

select rownum,* from County where rownum between 1 and 8

--获取所有符合查询条件的结果集的总行数

select count(*) from County

 

 

和第二节中的自定义假分页相似,这里只是获取分页显示数据集的方式有所区别,真分页是按需获取,假分页则是获取所有然后再进行筛选。实例源码如下:

 

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default4.aspx.cs" Inherits="Default4" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head id="Head1" runat="server">
    <title>ASP.NET分页之自定义存储过程分页(真分页)</title>
</head>
<body>
    <form id="form1" runat="server">
        <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" DataKeyNames="o_id"
            Width="400px">
            <Columns>
                <asp:BoundField DataField="rowIndex" HeaderText="行索引" SortExpression="rowIndex" ReadOnly="True" />
                <asp:BoundField DataField="o_id" HeaderText="编号" SortExpression="o_id" ReadOnly="True" />
                <asp:BoundField DataField="o_name" HeaderText="区县" SortExpression="o_name" />
                <asp:BoundField DataField="c_id" HeaderText="市编号" SortExpression="c_id" />
            </Columns>
        </asp:GridView>
        <br />
        <table border="0" cellpadding="0" cellspacing="0">
            <tr>
                <td>
                    共<asp:Label ID="lblPageCount" runat="server" ForeColor="Red"></asp:Label>页, 当前第<asp:Label
                        ID="lblCurrPage" runat="server" ForeColor="Red"></asp:Label>页&nbsp;&nbsp; 共<asp:Label
                            ID="lblTotalCount" runat="server" ForeColor="Red"></asp:Label>条记录, 每页显示<asp:Label
                                ID="lblPageSize" runat="server" Text="12" ForeColor="Red"></asp:Label>条&nbsp;&nbsp;
                </td>
                <td>
                    <asp:LinkButton ID="btnFirst" runat="server" OnClick="btnFirst_Click">首页</asp:LinkButton>&nbsp;
                    <asp:LinkButton ID="btnPrev" runat="server" OnClick="btnPrev_Click">上一页</asp:LinkButton>&nbsp;
                    <asp:LinkButton ID="btnNext" runat="server" OnClick="btnNext_Click">下一页</asp:LinkButton>&nbsp;
                    <asp:LinkButton ID="btnLast" runat="server" OnClick="btnLast_Click">尾页</asp:LinkButton>&nbsp;
                    跳到<asp:DropDownList ID="ddlPager" runat="server" Width="50" OnSelectedIndexChanged="ddlPager_SelectedIndexChanged"
                        AutoPostBack="true" />
                    页
                </td>
            </tr>
        </table>
    </form>
</body>
</html>

 

 

示例后台代码如下:

 

using System;

using System.Collections.Generic;

using System.Linq;

using System.Web;

using System.Web.UI;

using System.Web.UI.WebControls;

using System.Configuration;

using System.Data;



public partial class Default4 : System.Web.UI.Page
{

    //页面加载时默认显示第一页

    protected void Page_Load(object sender, EventArgs e)
    {

        if (!IsPostBack)
        {

            BindPaging("1");

        }

    }



    //首页按钮被点击

    protected void btnFirst_Click(object sender, EventArgs e)
    {

        BindPaging("1");

    }



    //上一页页按钮被点击

    protected void btnPrev_Click(object sender, EventArgs e)
    {

        BindPaging("-1");

    }



    //下一页页按钮被点击

    protected void btnNext_Click(object sender, EventArgs e)
    {

        BindPaging("+1");

    }



    //尾页按钮被点击

    protected void btnLast_Click(object sender, EventArgs e)
    {

        BindPaging("0");

    }



    //下拉列表框选项发生改变

    protected void ddlPager_SelectedIndexChanged(object sender, EventArgs e)
    {

        BindPaging(ddlPager.Text);

    }



    private void BindPaging(string page)
    {

        SqlDataSource sqlds = new SqlDataSource();

        sqlds.ConnectionString = ConfigurationManager.ConnectionStrings["connstr"].ConnectionString;

        sqlds.SelectCommand = "SELECT count(*) FROM [County]";

        sqlds.SelectCommandType = SqlDataSourceCommandType.Text;

        DataView dv = sqlds.Select(DataSourceSelectArguments.Empty) as DataView;



        int totalCount = int.Parse(dv[0][0].ToString());//总条数

        int pageSize = 12;//每页显示条数

        int pageCount = (totalCount % pageSize == 0) ? (totalCount / pageSize) : (totalCount / pageSize + 1);//总页数

        int currPage; //当前页数

        //设置当前页

        switch (page)
        {

            //首页

            case "1":

                currPage = 1;

                break;

            //下一页

            case "+1":

                currPage = int.Parse(lblCurrPage.Text) + 1;

                break;

            //上一页

            case "-1":

                currPage = int.Parse(lblCurrPage.Text) - 1;

                break;

            //尾页

            case "0":

                currPage = pageCount;

                break;

            //下拉列表框直接传值时

            default:

                currPage = int.Parse(page);

                break;

        }



        //加载DropDownList项

        if (!IsPostBack)
        {

            for (int i = 1; i <= pageCount; i++)
            {

                ddlPager.Items.Add(i.ToString());

            }

        }



        //设置分页信息的显示

        lblCurrPage.Text = currPage.ToString();

        lblPageCount.Text = pageCount.ToString();

        lblPageSize.Text = pageSize.ToString();

        lblTotalCount.Text = totalCount.ToString();



        //设置翻页按钮的可用性

        btnFirst.Enabled = btnPrev.Enabled = btnNext.Enabled = btnLast.Enabled = true;

        if (currPage == 1)
        {

            btnFirst.Enabled = btnPrev.Enabled = false;

        }

        if (currPage == pageCount)
        {

            btnNext.Enabled = btnLast.Enabled = false;

        }

        ddlPager.Text = currPage.ToString();



        //通过开始行和结束行的索引获取当前页要显示的数据集

        sqlds.SelectCommand = "sp_Paging_GetCounty";

        sqlds.SelectParameters.Add("startIndex", ((currPage - 1) * pageSize + 1).ToString());

        sqlds.SelectParameters.Add("endIndex", (currPage * pageSize).ToString());

        sqlds.SelectCommandType = SqlDataSourceCommandType.StoredProcedure;

        dv = sqlds.Select(DataSourceSelectArguments.Empty) as DataView;



        GridView1.DataSource = dv;

        GridView1.DataBind();

    }

}

 

 

运行效果如下:

 



 

在这一节中已经详细介绍了ASP.NET中的真分页,这种分页方式可以进行相应的扩充,以达到自己的需求,也可以添加一些查询条件,必须注意的是,若加查询条件,则存储过程和查询总记录条数的查询语句必须具备相同的查询条件

  • 大小: 18.2 KB
  • 大小: 57.2 KB
分享到:
评论

相关推荐

    通信电源蓄电池组容量性充放电试验三措一案.docx

    5G通信行业、网络优化、通信工程建设资料。

    铁塔维护检测手段.docx

    5G通信行业、网络优化、通信工程建设资料

    通信设备安装施工组织方案.doc

    5G通信、网络优化与通信建设

    299-教育行业信息化与数据平台建设分享.pptx

    299-教育行业信息化与数据平台建设分享.pptx

    手写数字和字母数据集binaryalphadigs.mat

    手写数字和字母数据集binaryalphadigs.mat

    变电站视频监控解决方案.doc

    5G通信行业、网络优化、通信工程建设资料

    PEMFC电堆输出电压模型,可计算效率、输出功率、电流、消耗功率以及等效内阻

    PEMFC电堆输出电压模型,可计算效率、输出功率、电流、消耗功率以及等效内阻

    创建型 结构型 设计型设计模式相关知识

    1、 设计思路 1、 创建型设计模式 创建型设计模式主要“关注对象的创建”。 1. 单例模式 单例模式:能不用就不用 ,他的目的就是为了让一个类只创建一个实例。 用法:把对象的创建权限关闭,提供一个人公开的静态方法,实现静态方法后将实例存放于静态的字段中,方法中返回。 单例模式会长期持有一个对象不会被释放,而普通实例不用就会被释放(当然必须是GC之后才会被释放)。 单例用途;数据临时存储的地方如静态字典,数据库连接池、线程池、IOC容器实例。   1.1懒汉式 设置构造函数为私有的,避免其他外部类可以对其实例化, 创建静态类来存储实例。 在静态方法中创建实例,避免多个线程同时调用方法,我们可以加线程锁, 在方法中使用双判断语句:最外层判断是为了提高运行速率,检查如果静态字段中已经存在实例了就可以直接return;第二层判断是避免创建多个对象实例。 1.2饿汉式1 静态构造函数:由CLR保证,静态构造函数只会在启动程序时候,由CLR自行创建。并且只会创建一次,相比较于懒汉式创建的更早,并且不需要担心会

    《通信工程概预算》模拟试题2.docx

    5G通信行业、网络优化、通信工程建设资料

    毕业设计:Java项目之jsp高校规章制度管理系统(源码 + 数据库 + 说明文档)

    论文目录: 第二章 需求分析与系统总体设计 - 5 - 2.1java的特点 - 5 - 2.2技术可行性 - 5 - 2.3可靠性和安全性特点 - 6 - 2.4系统总体设计 - 6 - 2.5JSP技术介绍 - 7 - 2.5.1 什么是JSP - 7 - 2.5.2 JSP技术特点 - 7 - 2.5.3 JSP开发WEB的几种方式 - 8 - 第三章 数据库的设计与实现 - 9 - 3.1数据库的需求分析 - 9 - 3.2数据库的逻辑设计 - 10 - 3.3 数据库的结构创建 - 10 - 第四章 后台系统和数据库的配置 - 13 - 4.1后台服务器配置 - 13 - 4.2后台数据库的配置 - 13 - 4.3后台全局配置文件 - 13 - 第五章 前端网络页面的开发与设计 - 14 - 5.1登录页面 - 14 - 5.2 管理员用户页面 - 15 - 5.3 注册用户页面 - 16 - 5.4主页面 - 17 - 5.5用户注册页面 - 18 - 5.6 规章制度管理页面 - 18 - 第六章 系统的安全性 - 19 - 6.1 session和cookie的安

    ONU、分光器验收规范.doc

    5G通信行业、网络优化、通信工程建设资料。

    99-煤矿安全生产标准化基本要求及评分方法.pdf

    99-煤矿安全生产标准化基本要求及评分方法.pdf

    node-v12.22.6-sunos-x64.tar.xz

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    475现场通讯器用户手册

    475现场通讯器用户手册

    node-v7.7.0.tar.xz

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    600A钳形电流表使用手册

    600A钳形电流表使用手册

    常见宏基站认识和设计讲解.pptx

    5G通信、网络优化与通信建设

    node-v12.16.3-sunos-x64.tar.xz

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    数据中心机房供电需求分析.pptx

    5G通信、网络优化与通信建设

    Binomial Self-compensation

    Binomial Self-compensation for Motion Error in Dynamic 3D Scanning

Global site tag (gtag.js) - Google Analytics