Java项目实战第8天:分页查询功能

​今天是刘小爱自学Java的第107天。

感谢你的观看,谢谢你。

话不多说,开始今天的学习:

image

一、分页概述

我们现在在网络上查询数据,通过关键字查询,一次性会查询出很多数据。

比如在浏览器上搜“刘小爱”,会有12万条。

如果要将其一次性地展现出来太困难了,需要浏览器不停地渲染数据才行。

这样对浏览器的损耗也很大。

所以为了解决这个问题,就引入了分页的功能,基本上大家都应该见到过分页的应用:

image

现在网站一般涉及到查询功能时,都会使用到分页,关于分页其中牵扯到3个重要的参数:

  • 当前页面的页码数pageNum。
  • 每页展示的数据条数pageSize。
  • 每页数据的起始索引startCount。

根据前端能得到的数据为:当前页码数和每页数据条数。

而去数据库中查询需要:数据的起始索引以及每页数据条数。

所以我们要找出其中的规律:

image

数据库中相关的数据有很多个,假设每页显示的数据为8个,那么

  • 第1页:从索引位为0开始的8条数据。

  • 第2页:从索引位为8开始的8条数据。

  • 第3页:从索引位为16开始的8条数据。

从中我们可以找出其中的规律为:

每页初始索引位=(页码数-1)页面数据量*

使用limt这个关键字即可完成sql语句编写。

思路分析完毕就可以开始编写代码了。

前端发送请求

image

其中关于静态页面,将数据写死了。这边主要只暂时考虑分页的功能实现。

在每个显示页码的地方绑定一个点击事件,其对应的函数即为getPageData()。

getPageData(pageNum,pageSize):

  • pageNum当前页面页码数。
  • pageSize当前页面数据条数。

事件绑定成功后,一点击对应的页码数,就会发送请求到服务器:

  • 请求对应后台中的RouteServlet。
  • 在pageQuery方法中处理该请求。
  • 请求中的参数数据为pageNum和pageSize这两个键值对。

二、后台代码编写

1web层

创建一个RouteServlet来接受请求,同时在pageQuery方法中编写具体的代码:

image

该层代码其实无外乎就是核心三步骤:获取请求数据、调用service层以及响应数据。

  • 请求中有两个键值对数据,通过getParameter()方法分别获取对应的值。

  • 再将它们作为参数,调用service层的方法具体处理。

  • 最后响应处理后的数据。

2service层

image

①分页数据三大参数

  • 当前页面页码数pageNum。
  • 当前页面数据条数pageSize。
  • 当前页面数据起始索引startCount。

其默认值分别为1,8,0,即第1页的数据就是从0索引位开始查询8条数据。

在最开始也分析过,它们之间的关系为:

startCount=(pageNum-1)*pageSize

不过现在前端有请求参数了,所以跟随请求参数动态变化。

②将字符串数据转换成int类型

请求中的数据是字符串,所以需要将其转化成int,在转换前需要对其做一个非空判断。

使用工具类StringUtils的isNotBlank()方法,可以对字符串做一个非空判断:

image

该工具类能够判断三种数据:字符串里什么都没有,null,字符串里只有空格。

所以功能更加地强大,也很实用。

③封装数据

从dao层查询数据,返回值为一个route对象集合,将该集合封装到一个map中,

最后再转换成json数据并返回给web层。

3dao层

利用service传来的pageSize和startCount这两个参数从数据库中查询数据。

image

请求本来是pageNum和pageSize参数。

上述service层主要的作用其实也就是将它们转换成了数据库查询需要的参数。

注意sql语句中的Limt的使用,即从第startCount索引位数据开始,查询pageSize条数据。

三、前端渲染页面

前端在接受到后台响应的数据之后,要将数据处理并渲染到对应的页面标签中:

image

响应数据是一个集合,既然如此肯定需要遍历数据,使用jQuery的forEach方法遍历数据。

同时在每次遍历时获取对应元素的值,将该值拼接到静态页面中。

最后使用id选择器将拼接后的数据渲染到页面对应的标签中。

最后

因为个人精力和时间受限,分页查询并没有完整地实现,关于前端数据渲染也没详述。

不过实现思路基本上是这么一个思路。

并且我觉得吧,学习很多时候不是为了学某个知识点,对我来说,学习最大的意义在于:

学会如何去学习,以及我有面对一切问题并想办法将其解决的勇气。

谢谢你的观看。

如果可以的话,麻烦帮忙点个赞,谢谢你。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352