ASP.NET分页之自定义存储过程分页(真分页)
- 博客分类:
- 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>页 共<asp:Label ID="lblTotalCount" runat="server" ForeColor="Red"></asp:Label>条记录, 每页显示<asp:Label ID="lblPageSize" runat="server" Text="12" ForeColor="Red"></asp:Label>条 </td> <td> <asp:LinkButton ID="btnFirst" runat="server" OnClick="btnFirst_Click">首页</asp:LinkButton> <asp:LinkButton ID="btnPrev" runat="server" OnClick="btnPrev_Click">上一页</asp:LinkButton> <asp:LinkButton ID="btnNext" runat="server" OnClick="btnNext_Click">下一页</asp:LinkButton> <asp:LinkButton ID="btnLast" runat="server" OnClick="btnLast_Click">尾页</asp:LinkButton> 跳到<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中的真分页,这种分页方式可以进行相应的扩充,以达到自己的需求,也可以添加一些查询条件,必须注意的是,若加查询条件,则存储过程和查询总记录条数的查询语句必须具备相同的查询条件
相关推荐
5G通信行业、网络优化、通信工程建设资料。
5G通信行业、网络优化、通信工程建设资料
5G通信、网络优化与通信建设
299-教育行业信息化与数据平台建设分享.pptx
手写数字和字母数据集binaryalphadigs.mat
5G通信行业、网络优化、通信工程建设资料
PEMFC电堆输出电压模型,可计算效率、输出功率、电流、消耗功率以及等效内阻
1、 设计思路 1、 创建型设计模式 创建型设计模式主要“关注对象的创建”。 1. 单例模式 单例模式:能不用就不用 ,他的目的就是为了让一个类只创建一个实例。 用法:把对象的创建权限关闭,提供一个人公开的静态方法,实现静态方法后将实例存放于静态的字段中,方法中返回。 单例模式会长期持有一个对象不会被释放,而普通实例不用就会被释放(当然必须是GC之后才会被释放)。 单例用途;数据临时存储的地方如静态字典,数据库连接池、线程池、IOC容器实例。 1.1懒汉式 设置构造函数为私有的,避免其他外部类可以对其实例化, 创建静态类来存储实例。 在静态方法中创建实例,避免多个线程同时调用方法,我们可以加线程锁, 在方法中使用双判断语句:最外层判断是为了提高运行速率,检查如果静态字段中已经存在实例了就可以直接return;第二层判断是避免创建多个对象实例。 1.2饿汉式1 静态构造函数:由CLR保证,静态构造函数只会在启动程序时候,由CLR自行创建。并且只会创建一次,相比较于懒汉式创建的更早,并且不需要担心会
5G通信行业、网络优化、通信工程建设资料
论文目录: 第二章 需求分析与系统总体设计 - 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的安
5G通信行业、网络优化、通信工程建设资料。
99-煤矿安全生产标准化基本要求及评分方法.pdf
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现场通讯器用户手册
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钳形电流表使用手册
5G通信、网络优化与通信建设
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提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
5G通信、网络优化与通信建设
Binomial Self-compensation for Motion Error in Dynamic 3D Scanning