Mysql学习总结(32)——MySQL分页技术详解
1.什么是数据分页:数据分页就是将很多条记录像书本一样分页,每页显示多少行记录;
2.为什么要数据分页:当我们进行sql语句查询时,假如数据有成千上万行记录,如果在同一个页面去显示,那这个页面得有多大,数据就要很多,而我们所需的记录又很少,不使用分页,查看起来那么繁琐,而且一不小心容易看着眼花。使用数据分页,就行书本一样,有页数,一目了然。相当简洁。
3.核心sql语句:SELECT * FROM stud LIMIT m,n ————m表示要显示的页数,n表示显示的记录行数
4.核心思想:
- 总行数(rows): select count(1) from stud;
- 每页显示的行数(PAGE_SIZE): 固定值---已知的一个常量
- 页数: pageSize= num/n + (num%n==0)?0:1
- 当前页号: currentPage
- 当前要显示的页面数据的起始行号和终止行号 :startRow: (currentPage-1)*pageSize
- 如何显示从startN开始的pageSize条记录 select * from stud limit startN, pageSize;
- 当前显示的开始页号:showStart=currentPage-showSize/2;
- 当前显示的结束页号:showEnd=showStart+showSize-1;
- 模糊查询:select count(*) from stud where 1=1 and........
5.成果图:
6.代码实现
需要的包和配置文件:
- myConUtil.jar----自己写的c3p0pool工具类
- commons-dbutils-1.4.jar
- mysql-connector-java-5.1.34-bin.jar
- c3p0-0.9.1.2.jar
- c3p0-config.xml
index.jsp
- <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
- <%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
- <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
- <html>
- <head>
- </head>
- <body>
- <a href='<c:url value="/PageServlet"></c:url>'>查看分页技术</a>
- </body>
- </html>
show,jsp
- <span style="font-size:12px;"><%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
- <%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
- <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
- <html>
- <head>
- <title>演示数据分页</title>
- <link rel="stylesheet" href='<c:url value="/css/table.css"></c:url>'
- media="screen">
- <script type="text/javascript">
- function onsub(obj){
- window.location.href="<c:url value='/PageServlet?page='></c:url>"+obj.value;
- }
- </script>
- </head>
- <body>
- <h3>以下是当前页的内容</h3>
- <form action="<c:url value='/PageServlet'/>" method="post" >
- 请输入要查询的关键字:<br/>
- 学号:<input type="text" name="serachId" value="${stud.id }"><br/>
- 姓名:<input type="text" name="serachName" value="${stud.name }"><br/>
- <input type="submit" value="搜索">
- </form>
- <table>
- <c:if test="${!empty map.datas}">
- <tr>
- <th>学号</th>
- <th>姓名</th>
- </tr>
- </c:if>
- <c:forEach items="${map.datas}" var="stud">
- <tr>
- <td>${stud.id }</td>
- <td>${stud.name }</td>
- </tr>
- </c:forEach>
- </table>
- <c:if test="${map.currentPage!=1}" var="boo">
- <a href="<c:url value='/PageServlet?page=${map.currentPage-1}'></c:url>" >上一页</a>
- </c:if>
- <c:forEach var="idx" begin="${map.showStart }" end="${map.showEnd }">
- <c:if test="${map.currentPage==idx}" var="boo">
- <font face="STCAIYUN"><a
- href="<c:url value='/PageServlet?page=${idx}'></c:url>">${idx}</a>
- </font>
- </c:if>
- <c:if test="${!boo}">
- <a href="<c:url value='/PageServlet?page=${idx}'></c:url>">${idx}</a>
- </c:if>
- </c:forEach>
- <c:if test="${map.currentPage!=map.pageCount}" var="boo">
- <a href="<c:url value='/PageServlet?page=${map.currentPage+1}'></c:url>">下一页</a>
- </c:if>
- <br/>
- <br/>
- <br/>
- <select onchange="onsub(this)">
- <c:forEach var="i" begin="1" end="${map.pageCount }">
- <option <c:if test="${i==map.currentPage }" >selected="selected" </c:if> value="${i}" >
- <a href="<c:url value='/PageServlet?page=${i}'></c:url>">第 ${i } 页</a>
- </option>
- </c:forEach>
- </select>
- </body>
- </html></span>
table.css
- <span style="font-size:12px;">table{
- color: green;
- border: 1px solid blue;
- border-collapse: collapse;
- width:500px;
- margin: auto;
- }
- td{
- border: 1px solid blue;
- }
- th{
- border: 1px solid blue;
- }
- body{
- text-align: center;
- }</span>
PageServlet.Java
- <span style="font-size:12px;">package cn.hncu.page1.servlet;
- import java.io.IOException;
- import java.sql.SQLException;
- import java.util.Map;
- import javax.servlet.ServletException;
- import javax.servlet.http.HttpServlet;
- import javax.servlet.http.HttpServletRequest;
- import javax.servlet.http.HttpServletResponse;
- import cn.hncu.page1.domain.Stud;
- import cn.hncu.page1.service.IPageService;
- import cn.hncu.page1.service.PageService;
- public class PageServlet extends HttpServlet {
- private IPageService service=new PageService();
- public void doGet(HttpServletRequest request, HttpServletResponse response)
- throws ServletException, IOException {
- doPost(request, response);
- }
- public void doPost(HttpServletRequest request, HttpServletResponse response)
- throws ServletException, IOException {
- request.setCharacterEncoding("utf-8");
- //这里是搜索区域的操作
- Stud stud=null;
- if(request.getMethod().equals("POST")){
- if (stud==null) {
- stud = new Stud();
- }
- String serachId = request.getParameter("serachId");
- String serachName = request.getParameter("serachName");
- stud.setId(serachId);
- stud.setName(serachName);
- request.getSession().setAttribute("stud", stud);
- }else{
- stud=(Stud) request.getSession().getAttribute("stud");
- if (stud==null) {
- stud = new Stud();
- }
- }
- //封装studs对象
- int currentPage=1;
- try {
- currentPage = Integer.parseInt(request.getParameter("page"));
- } catch (NumberFormatException e) {
- currentPage=1;
- }
- Map<String, Object> map=null;
- try {
- map=service.query(currentPage,stud);
- } catch (SQLException e) {
- e.printStackTrace();
- }
- map.put("currentPage", currentPage);
- //显示滚动页号
- int showStart=0;//从第几个页号开始显示
- int showEnd=0;//从第几个页号结束显示
- int showSize=10;//显示多少页数
- int pageCount=Integer.parseInt(""+map.get("pageCount"));
- if(showSize>pageCount){//显示页数大于于总页数
- showStart=1;
- showEnd=pageCount;
- }else{
- if(currentPage<=showSize/2){
- showStart=1;
- showEnd=showSize;
- }else{
- showStart=currentPage-showSize/2;
- showEnd=showStart+showSize-1;
- }
- }
- if(showEnd>pageCount){
- showEnd=pageCount;
- showStart=showEnd-showSize;
- }
- map.put("showStart", showStart);
- map.put("showEnd", showEnd);
- request.setAttribute("map", map);
- request.getRequestDispatcher("/jsps/show.jsp").forward(request, response);
- }
- }</span>
IPageService.java
- <span style="font-size:12px;">package cn.hncu.page1.service;
- import java.sql.SQLException;
- import java.util.Map;
- import cn.hncu.page1.domain.Stud;
- public interface IPageService {
- public Map<String, Object> query(int currentPage, Stud stud) throws SQLException;
- }</span>
PageService.java
- <span style="font-size:12px;"> package cn.hncu.page1.service;
- import java.sql.SQLException;
- import java.util.Map;
- import cn.hncu.page1.dao.PageDao;
- import cn.hncu.page1.dao.PageDaoJdbc;
- import cn.hncu.page1.domain.Stud;
- public class PageService implements IPageService{
- private PageDao dao=new PageDaoJdbc();
- @Override
- public Map<String, Object> query(int currentPage, Stud stud)
- throws SQLException {
- return dao.query(currentPage,stud);
- }
- }</span>
PageDao.java
- <span style="font-size:12px;">package cn.hncu.page1.dao;
- import java.sql.SQLException;
- import java.util.Map;
- import cn.hncu.page1.domain.Stud;
- public interface PageDao {
- public Map<String, Object> query(int currentPage, Stud stud) throws SQLException;
- }</span>
PageDaoJdbc.java
- <span style="font-size:12px;">package cn.hncu.page1.dao;
- import java.sql.SQLException;
- import java.util.HashMap;
- import java.util.List;
- import java.util.Map;
- import javax.sql.DataSource;
- import org.apache.commons.dbutils.QueryRunner;
- import org.apache.commons.dbutils.handlers.MapListHandler;
- import org.apache.commons.dbutils.handlers.ScalarHandler;
- import org.junit.Test;
- import cn.hncu.page1.domain.Stud;
- import cn.hncu.page1.service.IPageService;
- import cn.hncu.pool.C3p0Pool;
- public class PageDaoJdbc implements PageDao{
- private static final int PAGE_SIZE=10;
- @Override
- public Map<String, Object> query(int currentPage, Stud stud) throws SQLException {
- Map<String, Object> map=new HashMap<String, Object>();
- DataSource pool=C3p0Pool.getPool();
- QueryRunner qr=new QueryRunner(pool);
- String sql="select count(*) from stud where 1=1 ";
- if(stud.getId()!=null&&stud.getId().trim().length()>0){
- sql+="and id like '%"+stud.getId()+"%'";
- }
- if(stud.getName()!=null&&stud.getName().trim().length()>0){
- sql+="and name like '%"+stud.getName()+"%'";
- }
- int rows=Integer.parseInt(""+ qr.query(sql, new ScalarHandler()));
- int pageCount=rows/PAGE_SIZE+((rows%PAGE_SIZE==0)?0:1);
- map.put("pageCount", pageCount);
- int startRow=(currentPage-1)*PAGE_SIZE;
- map.put("startRow", startRow);
- String sql2="select * from stud where 1=1 ";//这种判断方法,很不错
- if(stud.getId()!=null&&stud.getId().trim().length()>0){
- sql2+="and id like '%"+stud.getId()+"%'";
- }
- if(stud.getName()!=null&&stud.getName().trim().length()>0){
- sql2+="and name like '%"+stud.getName()+"%' ";
- }
- sql2+="limit "+startRow+" , "+PAGE_SIZE;
- List<Map<String, Object>> datas=qr.query(sql2, new MapListHandler());
- map.put("datas", datas);
- return map;
- }
- }</span>
Stud.java
- <span style="font-size:12px;">package cn.hncu.page1.domain;
- public class Stud {
- private String id;
- private String name;
- public String getId() {
- return id;
- }
- public void setId(String id) {
- this.id = id;
- }
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- @Override
- public String toString() {
- return "Stud [id=" + id + ", name=" + name + "]";
- }
- }
Mysql学习总结(32)——MySQL分页技术详解的更多相关文章
- Linq学习总结1--参考Linq技术详解
2个要点: 1.linq操作的集合必须实现IEnumerable接口,所以在这3.0之前为实现该接口的集合需通过Cast或TypeOf方法转换成可Linq的集合; 2.查询式和Lame那啥表达式都可以 ...
- Android(java)学习笔记32:Android布局详解之一:FrameLayout
1. FrameLayout是最简单的布局了.所有放在布局里的控件,都按照层次堆叠在屏幕的左上角.后加进来的控件覆盖前面的控件. 在FrameLayout布局里,定义任何空间的位置相关的属性都毫无意义 ...
- Mysql高手系列 - 第8篇:详解排序和分页(order by & limit),及存在的坑
这是Mysql系列第8篇. 环境:mysql5.7.25,cmd命令中进行演示. 代码中被[]包含的表示可选,|符号分开的表示可选其一. 本章内容 详解排序查询 详解limit limit存在的坑 分 ...
- Mysql高手系列 - 第9篇:详解分组查询,mysql分组有大坑!
这是Mysql系列第9篇. 环境:mysql5.7.25,cmd命令中进行演示. 本篇内容 分组查询语法 聚合函数 单字段分组 多字段分组 分组前筛选数据 分组后筛选数据 where和having的区 ...
- Mysql高手系列 - 第14篇:详解事务
这是Mysql系列第14篇. 环境:mysql5.7.25,cmd命令中进行演示. 开发过程中,会经常用到数据库事务,所以本章非常重要. 本篇内容 什么是事务,它有什么用? 事务的几个特性 事务常见操 ...
- MySQL 8.0.20 安装教程图文详解(windows 64位)
MySQL 8.0.20 安装教程图文详解(windows 64位) 更新时间:2020年05月09日 15:09:04 转载 作者:瘦肉粥不加糖 这篇文章主要介绍了MySQL 8.0. ...
- MYSQL服务器my.cnf配置文档详解
MYSQL服务器my.cnf配置文档详解 硬件:内存16G [client] port = 3306 socket = /data/3306/mysql.sock [mysql] no-auto-re ...
- mysql服务性能优化—my.cnf配置说明详解
MYSQL服务器my.cnf配置文档详解硬件:内存16G [client]port = 3306socket = /data/3306/mysql.sock [mysql]no-auto-rehash ...
- ambari-server启动出现ERROR main] DBAccessorImpl:106 - Error while creating database accessor java.lang.ClassNotFoundException:com.mysql.jdbc.Driver问题解决办法(图文详解)
不多说,直接上干货! 问题详情 ambari-server启动时,报如下的错误 问题分析 注:启动ambari访问前,请确保mysql驱动已经放置在/usr/share/Java内且名字是mysql- ...
随机推荐
- 2015 Multi-University Training Contest 10 hdu 5412 CRB and Queries
CRB and Queries Time Limit: 12000/6000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Other ...
- oracle 解除锁表sql
select b.owner,b.object_name,a.session_id,a.locked_mode from v$locked_object a,dba_objects b where b ...
- 经常使用的MySQL语句整理
本文參考:http://www.blogjava.net/bolo 部分自己补充,长期更新 MySQL的SQL语句写法,除了那些主要的之外,另一些也算比較经常使用的,这里记录下来,以便以后查找. 好记 ...
- JAVAEE之--------过滤器设置是否缓存(Filter)
在网页中.每次的client訪问server.有部分不用反复请求.如有些图片,视频等就没有必要每次都请求,这样会让server增大工作量.为了防止这样.我们採用过滤器来设置client是都缓存. 參考 ...
- 数据挖掘算法学习(一)K-Means算法
博主近期实习開始接触数据挖掘,将学习笔记分享给大家.眼下用的软件是weka.下篇文章会着重解说. 转载请附上链接http://blog.csdn.net/iemyxie/article/details ...
- Cocos2d-x 2.2.3 使用NDK配置安卓编译环境问题之 Cannot find module with tag 'CocosDenshion/android' in import path
1.当做安卓移植的时候遇到例如以下问题: Android NDK: jni/Android.mk: Cannot find module with tag 'CocosDenshion/android ...
- 安卓系统底层C语言算法之測试參数是几个long型的算法
#include <stdio.h> #define BITS_PER_LONG (sizeof(unsigned long) * 8) //求一个数x是几个long的长度 #define ...
- UFLDL教程笔记及练习答案五(自编码线性解码器与处理大型图像**卷积与池化)
自己主动编码线性解码器 自己主动编码线性解码器主要是考虑到稀疏自己主动编码器最后一层输出假设用sigmoid函数.因为稀疏自己主动编码器学习是的输出等于输入.simoid函数的值域在[0,1]之间,这 ...
- 观光奶牛Sightseeing Cows (二分+spfa(dfs))
观光奶牛 农夫约翰已决定通过带他们参观大城市来奖励他们的辛苦工作!奶牛必须决定如何最好地度过他们的空闲时间. 幸运的是,他们有一个详细的城市地图,显示L(2≤L≤1000)主要地标(方便编号为1 .. ...
- element-ui 实现table整列的拖动
演示地址 1. 先动态渲染表头,给每一个表头添加一个class=virtual 的画虚线的类名,同时给每个表头加上鼠标点击.拖动.抬起事件:mousedown->mousemove->mo ...