Web之真假分页

2024-05-25 14:48
文章标签 web 分页 真假

本文主要是介绍Web之真假分页,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

      web设计中一个无法避免的问题就是分页显示。当数据量特别大的时候,我们不可能将所有的数据都在一个页面进行显示,如果这样将严重影响到它的美观性。所以在这个时候,分页显示则成为了我们的大功臣。当然分页也分两种,一种是真分页,一种是假分页,即:

     假分页:从数据库中选择所有记录后在分页。

    真分页:从数据库中选择当前页的记录

 

    首先先来说一下自带的分页功能(假分页):

    在.net中的GridView控件就自带分页显示功能,当然操作很简单,总共分成两步:

        1、在界面添加一个GridView控件,设置其属性AllowPaging的值为TruePageSize的值为n n 为每一页显示记录的条数),这样就设置成功了。

        2、将数据绑定到GridView控件上面就可以了。具体如下:

        protected void Page_Load(object sender, EventArgs e){if (!Page.IsPostBack){//页面第一次加载时调用绑定数据方法</span>BindNews();}}/// <summary>///绑定数据方法/// </summary></span>private void BindNews(){//查询数据,并将数据绑定到GridView1上面</span>GridView1.DataSource = newNewsManager().SelectAll();GridView1.DataBind();}/// <summary>/// 换页时的数据绑定功能/// </summary>/// <paramname="sender"></param>/// <paramname="e"></param></span>protected voidGridView1_PageIndexChanging(object sender, GridViewPageEventArgs e){//获取当前页的索引</span>GridView1.PageIndex  = e.NewPageIndex;//重新进行数据绑定</span>BindNews();}</span>


    通过上面的步骤就可以轻松得到分页的数据了。虽然可以实现想要的结果,但是还存在着一些问题,比如上面的绑定数据方法中绑定的是全部的新闻,每次执行的时候都会查询数据库中所有的记录,当记录达到一定量大的时候比如50万条,100万条等等,这个时候绑定的时候会是多么长的时间。所以将上面的情况定义成为假分页。与其相比,真分页则很好的解决了这个问题,下面再来见证一下真分页的神奇吧:

 

    在分页之前要进行数据查询,所以在这我建立了一个存储过程,用于查询分页数据,具体如下:

<span style="font-size:18px;"><span style="white-space:pre">	</span>ALTER PROCEDURE[dbo].[aspPageChoose]</span>@startPageint,</span>@endPageint</span>AS</span>BEGIN----建立临时表,用于储存</span></span>withtemptbl as (</span>selectROW_NUMBER() OVER (ORDER BY id desc)as rowNum ,* from news</span>)</span>select* from temptbl  where rowNum between@startPage and @endPage</span>END</span>

    其次是U层的建立,在界面上面放置两个控件,分别是AspNetPageGridView,将这两个控件每页显示的个数设置成对应的数值,最后就是对数据的绑定,进行显示,如下

protected voidPage_Load(object sender, EventArgs e){if (!Page.IsPostBack){//页面第一次加载时调用绑定数据方法</span>anp.RecordCount = <span style="color:#ff0000;">新闻的总数量</span>;int startpage = 1;int endpage =3;DataTable dt = newNewsManager().SelectAspNetPage(startpage, endpage);GridView1.PageSize =endpage - startpage + 1;GridView1.DataSource = dt;GridView1.DataBind();}}//进行换页显示数据</span>protected voidanp_PageChanged(object sender, EventArgs e){int startpage =anp.StartRecordIndex;int endpage = anp.EndRecordIndex;DataTable dt = newNewsManager().SelectAspNetPage(startpage, endpage);GridView1.PageSize = endpage -startpage + 1;GridView1.DataSource = dt;GridView1.DataBind();}</span>

    总结:常说对比出真知,通过上面的对比,可以很清楚的展示,真分页为我们打开了方便之门,除此之外还给我们编程带来了巨大的好处。上面的纯属自己摸索而来,如有什么不足,还请各位指点指点。

这篇关于Web之真假分页的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1001814

相关文章

解决JavaWeb-file.isDirectory()遇到的坑问题

《解决JavaWeb-file.isDirectory()遇到的坑问题》JavaWeb开发中,使用`file.isDirectory()`判断路径是否为文件夹时,需要特别注意:该方法只能判断已存在的文... 目录Jahttp://www.chinasem.cnvaWeb-file.isDirectory()遇

JavaWeb-WebSocket浏览器服务器双向通信方式

《JavaWeb-WebSocket浏览器服务器双向通信方式》文章介绍了WebSocket协议的工作原理和应用场景,包括与HTTP的对比,接着,详细介绍了如何在Java中使用WebSocket,包括配... 目录一、概述二、入门2.1 POM依赖2.2 编写配置类2.3 编写WebSocket服务2.4 浏

一文教你使用Python实现本地分页

《一文教你使用Python实现本地分页》这篇文章主要为大家详细介绍了Python如何实现本地分页的算法,主要针对二级数据结构,文中的示例代码简洁易懂,有需要的小伙伴可以了解下... 在项目开发的过程中,遇到分页的第一页就展示大量的数据,导致前端列表加载展示的速度慢,所以需要在本地加入分页处理,把所有数据先放

Redis存储的列表分页和检索的实现方法

《Redis存储的列表分页和检索的实现方法》在Redis中,列表(List)是一种有序的数据结构,通常用于存储一系列元素,由于列表是有序的,可以通过索引来访问元素,因此可以很方便地实现分页和检索功能,... 目录一、Redis 列表的基本操作二、分页实现三、检索实现3.1 方法 1:客户端过滤3.2 方法

Spring常见错误之Web嵌套对象校验失效解决办法

《Spring常见错误之Web嵌套对象校验失效解决办法》:本文主要介绍Spring常见错误之Web嵌套对象校验失效解决的相关资料,通过在Phone对象上添加@Valid注解,问题得以解决,需要的朋... 目录问题复现案例解析问题修正总结  问题复现当开发一个学籍管理系统时,我们会提供了一个 API 接口去

使用IntelliJ IDEA创建简单的Java Web项目完整步骤

《使用IntelliJIDEA创建简单的JavaWeb项目完整步骤》:本文主要介绍如何使用IntelliJIDEA创建一个简单的JavaWeb项目,实现登录、注册和查看用户列表功能,使用Se... 目录前置准备项目功能实现步骤1. 创建项目2. 配置 Tomcat3. 项目文件结构4. 创建数据库和表5.

手把手教你idea中创建一个javaweb(webapp)项目详细图文教程

《手把手教你idea中创建一个javaweb(webapp)项目详细图文教程》:本文主要介绍如何使用IntelliJIDEA创建一个Maven项目,并配置Tomcat服务器进行运行,过程包括创建... 1.启动idea2.创建项目模板点击项目-新建项目-选择maven,显示如下页面输入项目名称,选择

Java Web指的是什么

Java Web指的是使用Java技术进行Web开发的一种方式。Java在Web开发领域有着广泛的应用,主要通过Java EE(Enterprise Edition)平台来实现。  主要特点和技术包括: 1. Servlets和JSP:     Servlets 是Java编写的服务器端程序,用于处理客户端请求和生成动态网页内容。     JSP(JavaServer Pages)

BUUCTF靶场[web][极客大挑战 2019]Http、[HCTF 2018]admin

目录   [web][极客大挑战 2019]Http 考点:Referer协议、UA协议、X-Forwarded-For协议 [web][HCTF 2018]admin 考点:弱密码字典爆破 四种方法:   [web][极客大挑战 2019]Http 考点:Referer协议、UA协议、X-Forwarded-For协议 访问环境 老规矩,我们先查看源代码

EasyPlayer.js网页H5 Web js播放器能力合集

最近遇到一个需求,要求做一款播放器,发现能力上跟EasyPlayer.js基本一致,满足要求: 需求 功性能 分类 需求描述 功能 预览 分屏模式 单分屏(单屏/全屏) 多分屏(2*2) 多分屏(3*3) 多分屏(4*4) 播放控制 播放(单个或全部) 暂停(暂停时展示最后一帧画面) 停止(单个或全部) 声音控制(开关/音量调节) 主辅码流切换 辅助功能 屏