JAVA分页案例(基础思想)
java分页教程
java分页教程
Java分页是一种常见的数据处理技术,用于将大量数据分成多个较小的页面,以便于用户浏览和处理。
在这篇教程中,我将向你介绍使用Java进行分页的基本概念和实现方法。
我将涵
盖以下主题:
1. 分页的基本原理:我将解释为什么需要分页以及它是如何工作的。
我还将讨论分页的优势和应用场景。
2. 使用Java进行分页的常见方法:我将介绍在Java中实现分
页功能的一些常见方法和技术。
我会讨论使用原生Java开发
和使用第三方库的两种方法。
3. 原生Java分页方法:我将演示如何使用Java的基本数据结
构和算法来分页数据。
我会讨论如何计算分页参数,并演示一个简单的实现示例。
4. 使用第三方库进行分页:我将介绍一些常用的Java分页库,例如Spring Data Paging和Apache Commons Pagination。
我将
演示如何使用这些库来快速实现分页功能。
5. 分页的性能考虑:我将讨论如何在设计分页功能时考虑性能问题。
我会介绍如何处理大数据集、优化查询和缓存结果等技巧。
6. 分页的用户界面设计:我将提供一些建议和最佳实践,以帮助你设计一个好看和易于使用的分页用户界面。
这个教程旨在帮助Java开发者了解和掌握分页的基本概念和实现。
不管你是一个经验丰富的开发者还是一个新手,我相信这个教程都能帮助你提高你的Java编程技能。
我希望这个教程对你有所帮助。
祝你使用Java进行分页的过程中顺利!。
java分页实现原理
java分页实现原理Java分页实现原理在开发Web应用程序时,经常需要对大量数据进行分页展示,以提高用户体验和系统性能。
Java提供了多种方法来实现分页功能,本文将介绍一种常用的实现原理。
一、分页的概念和作用分页是将大量数据按照一定的规则分成若干页进行展示的一种技术。
在Web应用程序中,分页可以有效地减少单个页面的数据量,提高页面加载速度,同时也方便用户进行数据浏览和导航。
二、基本原理Java分页的基本原理是通过查询数据库获取数据,并根据每页显示的数量和当前页码来划分数据,然后将划分后的数据进行展示。
下面是具体的实现步骤:1. 获取总记录数:首先需要查询数据库获取数据的总记录数,以便计算总页数。
2. 计算总页数:根据总记录数和每页显示的数量,可以计算出总页数。
总页数 = 总记录数 / 每页显示的数量(向上取整)。
3. 获取当前页数据:根据当前页码和每页显示的数量,计算出数据的起始位置和结束位置,然后查询数据库获取当前页的数据。
4. 展示数据:将获取到的当前页数据进行展示,可以通过列表、表格等方式展示数据。
5. 分页导航:在页面底部显示分页导航条,包括首页、上一页、下一页、末页等按钮,用户可以通过点击按钮来切换页码。
6. 数据校验:在获取当前页数据之前,需要对页码进行校验,确保页码不超出总页数的范围。
三、关键代码示例下面是一个简单的Java代码示例,用于实现基本的分页功能:```java// 查询总记录数int totalRecords = dao.getTotalRecords();// 计算总页数int pageSize = 10; // 每页显示10条数据int totalPages = (int) Math.ceil((double) totalRecords / pageSize);// 校验页码int currentPage = 1; // 当前页码if (currentPage < 1) {currentPage = 1;} else if (currentPage > totalPages) {currentPage = totalPages;}// 计算起始位置和结束位置int startIndex = (currentPage - 1) * pageSize;int endIndex = startIndex + pageSize;// 查询当前页数据List<Data> dataList = dao.getDataList(startIndex, endIndex);// 展示数据for (Data data : dataList) {// 展示数据的代码}// 分页导航String navigation = generateNavigation(currentPage, totalPages);// 展示分页导航的代码```以上代码中,`dao`代表数据访问对象,`Data`代表数据实体类。
最简单的java分页算法(转)
最简单的java分页算法(转)
定义两个Vector,⼀个为储存查询所有记录的totalV,另⼀个储存当前页的记录currentPageV;总的记录数:inttotalSize=totalV.getSize();
每页显⽰的记录数:intcountPerPage;
总页数:inttotalPageNum=totalSize/countPerPage;
//如果总的记录数和每页记录数的余数⼤于零,
//那么总的页数为他们的整除结果加⼀
if(totalSize%countPerPage>0){
totalPageNum=totalSize/countPerPage+1;
}
当前的页数:pageNum;
for(intj=0;j//分页,根据当前的页数和每页显⽰的记录数从totalV中取出记录
//往currentPageV中添加记录;
//如果当前记录在(当前页码-1)每页显⽰记录数(包括等于)
//和当前页码每页显⽰记录数(不包括等于)之间的时候;
//就属于该页的数据
if((j>=(pageNum-1)countPerPage)&&(j
currentPageV.addElement(totalV.get(j));
}
//当currentPageV记录数等于每页显⽰记录数,
//停⽌往currentPageV中添加记录
if(currentPageV.size()==countPerPage){
break;
}
}
那么,当前页中显⽰的记录,就是currentPageV中的记录。
Java培训JSP分页实例四
分页技术,相信大家已经用得很多了,像在网上浏览文章、图片等都会用到分页的技术。
分页:顾名思义就是把查询出来的内容分成几部分,每一部分显示在‘一个’页面上。
对分页这个术语就不多解释了,分页有什么好处,有什么缺点,大家百度一下吧。
下面介绍我用过的一下分页技术:一、纯JSP(页面)分页技术二、Struts分页技术三、DisplayTag分页技术解释一下:纯JSP(页面)分页技术,像我们之前说的,就是JSP的设计(没有JA V ABEAN),所有的java语句(业务处理—数据库的链接)、javaScript、样式Css等都凑在一个页面(JSP)上,一方面使得页面混乱,可读性低,不易维护;另一方面是业务处理完全暴露在页面上,安全性没有得到保障;当然还有页面之间的耦合性高、程序不过健壮等。
Struts分页,之前也说过,我们使用Struts技术,主要是把在页面(JSP)的java语句(业务处理等)移植到Action(javabean),降低页面的耦合性,提高系统的安全性等。
DisplayTag技术呢,是一个比较方便使用的分页技术,它会自动帮我们生成一些HTML 的属性值(像table、tr、td)等,不用我们手工设计页面的显示方式。
对于这三种分页技术,它们都各有好处和缺点。
像jsp、struts 对DisplayTag的对比,jsp、struts的话,是接受我们输入的参数,如我们根据参数(第几页、每页显示的条数)去判断我们要在那条数据开始查找(遍历)我们想要的数据。
比如说:我们要查的数据有100条,每页显示10条记录,当我们输入第5页时,那么就是5*10=50,我们的数据集游标就指向第51条记录了,在往下找9条记录。
即我们每次翻页的话,最多也是找10条记录,性能就很快。
假如是displayTag技术的话,不管你是要显示第几页,它每次都要查找数据库的全部记录,在根据我们输入的参数,显示相应的数据而已,这就无疑加重了系统资源的开销。
java 集合分页方法
java 集合分页方法在Java中,可以使用集合(Collection)和分页技术来实现分页功能。
以下是一个简单的Java分页方法的示例:```javaimport ;import ;public class PaginationHelper<T> {private int pageSize;private int currentPage;private List<T> dataList;public PaginationHelper(int pageSize, int currentPage, List<T> dataList) {= pageSize;= currentPage;= dataList;}public List<T> getPageData() {int start = (currentPage - 1) pageSize;int end = start + pageSize;if (start < 0) {start = 0;}if (end > ()) {end = ();}if (start >= end) {return new ArrayList<>();} else {return (start, end);}}}```这个`PaginationHelper`类包含一个泛型类型`T`,表示要分页的数据类型。
构造函数接受三个参数:每页的大小、当前页码和数据列表。
`getPageData()`方法返回当前页的数据列表。
它首先计算起始和结束索引,然后使用`subList()`方法从数据列表中提取出当前页的数据。
如果起始索引小于0或大于数据列表的大小,则返回一个空列表。
使用示例:```javaList<String> dataList = new ArrayList<>();// 添加数据到dataList中...PaginationHelper<String> paginationHelper = new PaginationHelper<>(10, 1, dataList);List<String> pageData = ();```在这个示例中,我们创建了一个`PaginationHelper`对象,将每页大小设置为10,当前页码设置为1,并将数据列表传递给构造函数。
java手动分页处理
java⼿动分页处理经常我们在操作数据库的时候都会⽤到分页,⽽且很多框架也提供了分页功能,像PageHelper.但是在有些项⽬中,需要将数据查询出来进⾏⼿动分页,那么原理是什么呢?
其实很简单,⾸先需要知道数据总量,如果不知道数据总量,那么就要指定数据总量:totalCount 然后每页查询多少条数据,需要指定.我们默认pageSize=100
然后就进⾏分页了,下⾯是分页的代码
// 分页
short pageSize = 100;
int pageNum = totalCount / pageSize;
int surplus = totalCount % pageSize;//是不是整除
if (surplus > 0) {
pageNum = pageNum + 1;
}
for(int i = 0; i < pageNum; i++){
int pageBegin = i * pageSize;
//传⼊pageBegin,pageSize进⾏业务逻辑处理
}
上⾯是将所有数据进⾏分页处理.然后通过jdbc操作数据库,查询出业务数据.。
java分页写法
在Java中,分页是在处理大量数据时一种常见的需求。
通常,我们使用一些参数,比如页数和每页条目数,来实现分页。
以下是一个简单的Java分页写法的示例,使用了一个名为Pagination的辅助类:import java.util.List;public class Pagination<T> {private List<T> items;private int pageSize;private int currentPage;public Pagination(List<T> items, int pageSize) {this.items = items;this.pageSize = pageSize;this.currentPage = 1; // 默认为第一页}public List<T> getCurrentPageItems() {int startIndex = (currentPage - 1) * pageSize;int endIndex = Math.min(startIndex + pageSize, items.size());return items.subList(startIndex, endIndex);}public int getTotalPages() {return (int) Math.ceil((double) items.size() / pageSize);}public void nextPage() {if (currentPage < getTotalPages()) {currentPage++;}}public void previousPage() {if (currentPage > 1) {currentPage--;}}// Getters and setters for other attributes as neededpublic static void main(String[] args) {// 示例用法List<String> dataList = List.of("Item1", "Item2", "Item3", "Item4", "Item5", "Item6", "Item7", "Item8");// 设置每页显示的条目数int pageSize = 3;Pagination<String> pagination = new Pagination<>(dataList, pageSize);// 获取并打印第一页的数据System.out.println("Page 1: " + pagination.getCurrentPageItems());// 翻到下一页pagination.nextPage();// 获取并打印第二页的数据System.out.println("Page 2: " + pagination.getCurrentPageItems());// 可以根据需要进行其他操作,比如跳转到指定页等}}这个例子中,Pagination类包含了一些基本的分页功能,包括获取当前页的数据、获取总页数、翻到下一页、翻到上一页等。
JavaWeb学习之分页查询实例
JavaWeb学习之分页查询实例⼀、环境搭建客户端(发送请求)=> Servlet(处理请求,1、指定处理Service 2、指定对应页⾯) => Service(业务处理。
1、调⽤具体Dao并对返回数据做对应处理) => Dao(数据库操作。
单⼀增删改查)基本结构如下图⼆、代码实现分页 1、Sql语句(Sql Server 2012及以上) SELECT * FROM 表名 order by 排序字段OFFSET (当前页-1)*页容量ROWS FETCH next页容量rows only 2、domain包⽤于存储数据实体结构 2.1、PageBean.java1/**2* PageBean<T>,泛型可以提⾼其复⽤性3* ⽤于分页:4* 1、页容量(PageSize)5* 2、当前页⾯(PageIndex)6* 3、总页数(PageCount)7* 4、总条数(PageTotal)8* 5、分页数据集合(List)9*/10public class PageBean<T> {11private int PageSize;12private int PageIndex;13private int PageCount;14private int PageTotal;15private List<T> list;16public int getPageSize() {17return PageSize;18 }19public void setPageSize(int pageSize) {20 PageSize = pageSize;21 }22public int getPageIndex() {23return PageIndex;24 }25public void setPageIndex(int pageIndex) {26 PageIndex = pageIndex;27 }28public int getPageCount() {29return PageCount;30 }31public void setPageCount(int pageCount) {32 PageCount = pageCount;33 }34public int getPageTotal() {35return PageTotal;36 }37public void setPageTotal(int pageTotal) {38 PageTotal = pageTotal;39 }40public List<T> getList() {41return list;42 }43public void setList(List<T> list) {44this.list = list;45 }46 } 2.2、UserInfo1public class UserInfo {2private String UName;3private Date SubTime;//java.util.Date4private String Remark;5public String getUName() {6return UName;7 }8public void setUName(String uname) {9 UName = uname;10 }11public Date getSubTime() {12return SubTime;13 }14public void setSubTime(Date subTime) {15 SubTime = subTime;16 }17public String getRemark() {18return Remark;19 }20public void setRemark(String remark) {21 Remark = remark;22 }23 } 3、dao.impl包实现dao包中的接⼝1public class UserInfoDaoImpl implements IUserInfoDao {23/**4 * 获取分页数据5*/6 @Override7public List<UserInfo> getUserInfoByPageIndex(int p_intPageIdex) throws SQLException {8 QueryRunner runner= new QueryRunner(JDBCUtil.getDataSource());9return runner.query("select * from UserInfo order by Id offset ? row fetch next ? row only",10new BeanListHandler<UserInfo>(UserInfo.class), (p_intPageIdex-1)*PAGE_SIZE,PAGE_SIZE);11 }1213/**14 * 获取总记录数15*/16 @Override17public int getUserInfoCount() throws SQLException {18 QueryRunner runner= new QueryRunner(JDBCUtil.getDataSource());19 Long countLong= (Long) runner.query("select Count(*) from UserInfo",new ScalarHandler());20return countLong.intValue();//Long类型获取int类型的值21 }22 } 4、service.impl包实现service包中的接⼝1public class UserInfoServiceImpl implements IUserInfoService {23 @Override4public PageBean<UserInfo> getPageList(int p_intPageIndex) throws SQLException {5 PageBean<UserInfo> bean=new PageBean<UserInfo>();6 bean.setPageIndex(p_intPageIndex);7int pageSize=IUserInfoDao.PAGE_SIZE;8 bean.setPageSize(pageSize);9 IUserInfoDao dao=new UserInfoDaoImpl();10 bean.setList(dao.getUserInfoByPageIndex(p_intPageIndex));11int count=dao.getUserInfoCount();12 bean.setPageCount(count);1314//200,10 2015//201,10 1116 bean.setPageTotal(count % pageSize == 0 ? count / pageSize : (count / pageSize) + 1);17return bean;18 }19 } 5、servlet调⽤service.impl中的⽅法1public class UserInfoServlect extends HttpServlet {23 @Override4protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {5try {67int intPageIndex = 1;8if(req.getParameter("pageIndex")!=null) {9 intPageIndex=Integer.parseInt(req.getParameter("pageIndex"));10 }11 IUserInfoService service=new UserInfoServiceImpl();12 PageBean<UserInfo> bean= service.getPageList(intPageIndex);13 req.setAttribute("bean", bean);14 req.getRequestDispatcher("Index.jsp").forward(req, resp);15 } catch (SQLException e) {1617 e.printStackTrace();18 }19 }2021 @Override22protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {2324 doGet(req, resp);25 }26 } 6、创建jsp⽂件 6.1、导⼊标签库 把jstl包复制到⼯程lib⽬录下,使⽤<%@ taglib prefix="c" uri="/jsp/jstl/core" %>此代码将jstl标签库导⼊到当前页⾯ 注意:Index.jsp⽂件是创建在WebContent⽬录下 6.2、完整代码1 <%@ page language="java" contentType="text/html; charset=UTF-8"2 pageEncoding="UTF-8"%>3 <%@ taglib prefix="c" uri="/jsp/jstl/core" %>4<!DOCTYPE html>5<html>6<head>7<meta charset="UTF-8">8<title>Insert title here</title>9</head>10<body>11<TABLE border="1" width="700">12<TR>13<TD>姓名</TD>14<TD>时间</TD>15<TD>备注</TD>16</TR>17<c:forEach items="${bean.list }" var="userInfo">18<TR>19<TD>${userInfo.UName }</TD>20<!-- 根据 JavaBeans 规范,属性的前两个字母不能是⼀⼤⼀⼩,或者是⼀⼩⼀⼤。
JavaWeb简单的分页显示实例代码
JavaWeb简单的分页显⽰实例代码本⽂通过两个⽅法:(1)计算总的页数。
(2)查询指定页数据,实现简单的分页效果。
思路:⾸先得在 DAO 对象中提供分页查询的⽅法,在控制层调⽤该⽅法查到指定页的数据,在表⽰层通过 EL 表达式和JSTL 将该页数据显⽰出来。
先给⼤家展⽰下效果图:题外话:该分页显⽰是⽤ “表⽰层-控制层-DAO层-数据库”的设计思想实现的,有什么需要改进的地⽅⼤家提出来,共同学习进步。
废话不多说了,开始进⼊主题,详细步骤如下所⽰:1.DAO层-数据库JDBCUtils 类⽤于打开和关闭数据库,核⼼代码如下:import java.sql.Connection;import java.sql.DriverManager;import java.sql.PreparedStatement;import java.sql.ResultSet;import java.sql.SQLException;public class JDBCUtils {private Connection conn=null;private PreparedStatement pstmt=null;/*** connect 连接数据库* @return*/public Connection connect(){String user="root";String password="1234";String driverClass = "com.mysql.jdbc.Driver";String jdbcUrl = "jdbc:mysql://localhost:3306/book";try {Class.forName(driverClass);conn = DriverManager.getConnection(jdbcUrl, user, password);} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}return conn;}/*** close 关闭数据库* @param conn* @param pstmt* @param resu*/public void close(Connection conn,PreparedStatement pstmt,ResultSet result){if(conn != null){try {conn.close();} catch (SQLException e) {// TODO Auto-generated catch block}}if(pstmt != null){try {pstmt.close();} catch (SQLException e) {// TODO Auto-generated catch blocke.printStackTrace();}}if(result != null){try {result.close();} catch (SQLException e) {// TODO Auto-generated catch blocke.printStackTrace();}}}}UserDao 类中的⽅法 getPage() 和⽅法 listUser() 分别⽤来计算总页数和查询指定页的数据,核⼼代码如下:import java.sql.Connection;import java.sql.PreparedStatement;import java.sql.ResultSet;import java.sql.SQLException;import java.util.ArrayList;import java.util.List;import com.db.JDBCUtils;public class UserDao {/*** 计算总的页数* @return*/public int getPage(){int recordCount=0,t1=0,t2=0;PreparedStatement pstmt=null;ResultSet result=null;JDBCUtils jdbc=new JDBCUtils();Connection conn=jdbc.connect();String sql="select count(*) from books";try {pstmt=conn.prepareStatement(sql);result=pstmt.executeQuery();result.next();recordCount=result.getInt(1);t1=recordCount%5;t2=recordCount/5;} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}finally{jdbc.close(conn, pstmt, result);}if(t1 != 0){t2=t2+1;}return t2;}/*** 查询指定页的数据* @param pageNo* @return*/public List<User> listUser(int pageNo){PreparedStatement pstmt=null;ResultSet result=null;List<User> list=new ArrayList<User>();int pageSize=5;int page=(pageNo-1)*5;JDBCUtils jdbc=new JDBCUtils();Connection conn=jdbc.connect();String sql="select * from books order by id limit ?,?";try {pstmt=conn.prepareStatement(sql);pstmt.setInt(1, page);pstmt.setInt(2, pageSize);result=pstmt.executeQuery();while(result.next()){User user=new User();user.setId(result.getInt(1));user.setName(result.getString(2));user.setNumber(result.getString(3));list.add(user);}} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}finally{jdbc.close(conn, pstmt, result);}return list;}}User 类⽤于存储查询到的数据,核⼼代码如下:public class User {private int id;private String name;private String number;public int getId() {return id;}public void setId(int id) {this.id = id;}public String getName() {return name;}public void setName(String name) { = name;}public String getNumber() {return number;}public void setNumber(String number) {this.number = number;}}2.控制层ListUser 类内部调⽤ UserDao 对象查询数据并指派页⾯显⽰数据,核⼼代码如下:import java.io.IOException;import java.io.PrintWriter;import java.util.ArrayList;import java.util.List;import javax.servlet.ServletException;import javax.servlet.http.HttpServlet;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import er;import erDao;public class ListUser extends HttpServlet {public ListUser() {super();}public void destroy() {super.destroy(); // Just puts "destroy" string in log// Put your code here}public void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {doPost(request, response);}public void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {response.setCharacterEncoding("utf-8");int pageNo = 1;UserDao userdao=new UserDao();List<User> lists=new ArrayList<User>();String pageno=request.getParameter("pageNos");if(pageno != null){pageNo=Integer.parseInt(pageno);}lists=userdao.listUser(pageNo);int recordCount=userdao.getPage();request.setAttribute("recordCount", userdao.getPage());request.setAttribute("listss", lists);request.setAttribute("pageNos", pageNo);request.getRequestDispatcher("userlist.jsp").forward(request, response);}public void init() throws ServletException {// Put your code here}}3.表⽰层输出页⾯ userlist.jsp ,使⽤ EL 和 JSTL 输出查询结果,核⼼代码如下:<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%><%@ taglib prefix="c" uri="/jsp/jstl/core" %><%@ taglib uri="/jsp/jstl/fmt" prefix="fmt"%><%@ taglib uri="/jsp/jstl/functions" prefix="fn"%><%String path = request.getContextPath();String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"><html><head><base href="<%=basePath%>"><title>My JSP 'userlist.jsp' starting page</title><meta http-equiv="pragma" content="no-cache"><meta http-equiv="cache-control" content="no-cache"><meta http-equiv="expires" content="0"><meta http-equiv="keywords" content="keyword1,keyword2,keyword3"><meta http-equiv="description" content="This is my page"><!--<link rel="stylesheet" type="text/css" href="styles.css">--><style type="text/css">th,td{width: 150px;border: 2px solid gray;text-align: center;}body{text-align: center;}a{text-decoration: none;}table {border-collapse: collapse;}</style></head><body><h2 align="center">图书信息</h2><table align="center"><tr><td>书号</td><td>书名</td><td>库存量</td></tr></table><table align="center"><c:forEach items="${listss}" var="person"><tr><td class="hidden-480">${person.id}</td><td class="hidden-480">${ }</td><td class="hidden-480">${person.number }</td></tr></c:forEach></table><br><c:if test="${pageNos>1 }"><a href="ListUser?pageNos=1" >⾸页</a><a href="ListUser?pageNos=${pageNos-1 }">上⼀页</a></c:if><c:if test="${pageNos <recordCount }"><a href="ListUser?pageNos=${pageNos+1 }">下⼀页</a><a href="ListUser?pageNos=${recordCount }">末页</a></c:if><form action="ListUser"><h4 align="center">共${recordCount}页  <input type="text" value="${pageNos}" name="pageNos" size="1">页<input type="submit" value="到达"></h4></form></body></html>以上所述是⼩编给⼤家介绍的Java Web 简单的分页显⽰实例代码,希望对⼤家有所帮助,如果⼤家有任何疑问请给我留⾔,⼩编会及时回复⼤家的。
java后端实现分页Page_idea使用pagehelper实现后端分页功能的步骤详解
java后端实现分页Page_idea使用pagehelper实现后端分页功能的步骤详解在Java后端实现分页功能,可以使用PageHelper这个开源的分页插件。
PageHelper可以方便地对查询结果进行分页处理,实现结果集分页展示。
下面是使用PageHelper实现后端分页功能的步骤详解。
步骤一:添加依赖步骤二:配置PageHelper在项目的配置文件中,通常是application.properties或application.yml中,添加PageHelper的配置。
以下是一个示例:在application.properties中:```# PageHelper配置#开启分页支持pagehelper.helper-dialect=mysqlpagehelper.reasonable=truepagehelper.support-methods-arguments=truepagehelper.params=count=countSql```在application.yml中:```# PageHelper配置#开启分页支持pagehelper:helper-dialect: mysqlreasonable: truesupport-methods-arguments: trueparams: count=countSql```步骤三:设置分页参数在需要进行分页的查询方法中,使用PageHelper的startPage方法来设置分页参数。
startPage方法有多个重载方法,根据需要选择适合的方法。
以下是一个使用PageHelper进行分页查询的示例:```public class ProductServiceprivate ProductMapper productMapper;public PageInfo<Product> getProductList(int pageNum, int pageSize)PageHelper.startPage(pageNum, pageSize);List<Product> productList = productMapper.getProductList(;return new PageInfo<>(productList);}```步骤四:返回分页结果将分页查询的结果返回给前端进行展示。
关于Java中List对象的分页思想,按10个或者n个数对list进行分组
关于Java中List对象的分页思想,按10个或者n个数对list进⾏分组 try {List<String> timelist = DateUtils.getDateListBySETime("2015-08-01", "2015-11-30");if(timelist!=null&&timelist.size()>0){int SIZE = 10;int page = (timelist.size() + SIZE - 1)/SIZE;List<String> newtimelist=null;for(int i = 0;i < page;i++) {newtimelist=new ArrayList<String>();if(i==page-1){newtimelist=timelist.subList(i*SIZE, timelist.size());}else {newtimelist=timelist.subList(i*SIZE, i*SIZE+SIZE);}// markToDBLineByDate(timelist.get(0),timelist.get(timelist.size()-1),"1");System.out.println("~~~时间:"+newtimelist.get(0)+"~~~~~~~结束时间:"+newtimelist.get(newtimelist.size()-1));}}} catch (Exception e) {e.printStackTrace();}/*** 根据开始时间和结束时间把时间集合输出* @param startTime* @param endTime* @return* @throws Exception*/public static List<String> getDateListBySETime(String startTime, String endTime) throws Exception {if(StringUtils.isNotBlank(startTime) && StringUtils.isNotBlank(endTime)){//格式转换SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd");//开始⽇期Date sDate = sf.parse(startTime);//结束⽇期Date eDate = sf.parse(endTime);List<String> list = new ArrayList<String>();//⾸先加⼊第⼀项list.add(startTime);//当开始时间⼩于等于结束时间的时候while(sDate.getTime()<eDate.getTime()){//开始时间+1天Calendar sc = Calendar.getInstance();sc.setTime(sDate);sc.add(sc.DAY_OF_MONTH,+1);//赋给开始时间sDate = sc.getTime();//赋给集合list.add(sf.format(sDate));}return list;}return null;}。
java多线程数据分页处理实例讲解
java多线程数据分页处理实例讲解在数据的最终结果上,我们能够通过分类的⽅法,准备的筛选出不同类别结果的信息。
这⾥我们发散⼀下思维,在Java中对于数据⼤量处理的,多线程是⼀个⾮常常见的代表,我们可以⽤分页来处理多线程的数据问题。
下⾯我们对分类的类型进⾏了解,然后带来两种分页在多线程的逻辑。
1.常见的分页类型传统的:采⽤传统的分页⽅式,可以明确的获取数据信息,如有多少条数据,分多少页显⽰等。
下拉式:采⽤下拉式的分页⽅式,⼀般⽆法获取明确的数据数量相关的信息,但在分页操作以后,仍然可以看到之前查询的数据。
2.分页式查询逻辑int pageSize = 100;int currentPageLength = 0;int pageIndex = 0;ExecutorService exe = newFixedThreadPool(Runtime.getRuntime().availableProcessors());do {int offset = pageIndex * pageSize;List<TradeInfo> tradeInfos = tradeInfoService.findTradeInfoBysPage(queryParams,offset,pageSize);if (null != tradeInfos && tradeInfos.size() > 0) {currentPageLength = tradeInfos.size();TradeInfoProcesserTask task = new TradeInfoProcesserTask(tradeInfos );exe.execute(task);pageIndex++;}else{System.out.println("Page Query TradeInfo Got NOTHING! Break query loop!");break;}} while (currentPageLength == pageSize);exe.shutdown();while(true) {if(exe.isTerminated()){doOtherThings();System.out.println("分页式多线程处理数据完毕!");break;}}3.数据处理逻辑public class TradeInfoProcesserTask implements Runnable{private volatile List<TradeInfo> tradeInfos;public TradeInfoProcesserTask (List<TradeInfo> _tradeInfos){tradeInfos = _tradeInfos;}@Overridepublic void run() {processTradeInfos();}private void processTradeInfos(){//do something with tradeInfos .....}}到此这篇关于java多线程数据分页处理实例讲解的⽂章就介绍到这了,更多相关分页处理java多线程的数据内容请搜索以前的⽂章或继续浏览下⾯的相关⽂章希望⼤家以后多多⽀持!。
java分页原理
java分页原理Java分页原理随着网络技术的发展,网站中的数据量也越来越大,因此在网站中使用分页技术已经变得越来越普遍。
Java分页技术是一种常见的实现分页的方法,本文将介绍Java分页的原理及其实现方法。
Java分页原理Java分页的原理是将数据按照一定的规则进行划分,将数据分成多个页面进行展示。
在Java中实现分页一般需要以下步骤:1. 获取总记录数:在分页之前,需要获取数据的总记录数,以便计算总页数。
通常可以使用SQL语句中的count函数来获取总记录数。
2. 计算总页数:在获取总记录数后,可以根据每页显示的记录数来计算总页数。
计算公式为:总页数= (总记录数+ 每页显示的记录数 - 1) / 每页显示的记录数。
3. 显示当前页数据:根据当前页码,从数据库中获取对应的数据,然后将数据显示在页面上。
4. 显示分页导航:在页面上显示分页导航,包括上一页、下一页、总页数等信息,方便用户进行页面切换。
Java分页实现方法在Java中实现分页通常有两种方法:使用SQL语句实现分页和使用分页插件实现分页。
1. 使用SQL语句实现分页使用SQL语句实现分页的方法比较简单,只需要在SQL语句中添加limit子句即可。
limit子句的格式为:limit 起始记录数,每页显示的记录数。
例如,获取第2页数据,每页显示10条记录,SQL语句为:SELECT * FROM table_name LIMIT 10 OFFSET 10。
2. 使用分页插件实现分页使用分页插件实现分页的方法相对来说比较复杂,但是可以提高开发效率和代码可读性。
目前常用的分页插件有MyBatis分页插件、Hibernate分页插件等。
以MyBatis分页插件为例,实现分页需要以下步骤:(1)在pom.xml文件中添加MyBatis分页插件的依赖。
(2)在MyBatis的配置文件中添加分页插件的配置。
(3)在Mapper接口中定义查询方法,使用PageHelper.startPage方法开启分页。
Java实现简单的分页功能
Java实现简单的分页功能本⽂实例为⼤家分享了Java实现分页功能的具体代码,供⼤家参考,具体内容如下不⽤根据改变SQL的形式去查询;直接查询所有的数据,根据页码⾃动显⽰数据;分页对象public class PageUtils implements Serializable {/****/private static final long serialVersionUID = -5247614532234782640L;public final static String PAGE = "page";public final static String PAGE_NO = "pageno";public final static String PAGE_SIZE = "pagesize";private long pageSize=10;//每页显⽰记录数private long firstResult=0;//当页第⼀条记录号private long totalCount;//总记录数private long totalPage;//总页码private long pageNo=1;//当前页码private List<?> sumData;//此集合可⽤来保存合计数据private List<?> data;//查询结果public long getPageSize() {return pageSize;}public void setPageSize(long pageSize) {this.pageSize = pageSize;}public long getFirstResult() {if(pageNo>0){firstResult=pageSize * (pageNo -1);}else{firstResult = 0;}return firstResult;}public long getNextPageResult(){if(pageNo>0){return pageSize*(pageNo-1);}else{return pageNo;}}public void setFirstResult(long firstResult) {this.firstResult = firstResult;}public long getTotalCount() {return totalCount;}public void setTotalCount(long totalCount) {this.totalCount = totalCount;totalPage = this.totalCount/pageSize;if (totalPage == 0 || totalCount % pageSize != 0) {totalPage++;}}public long getTotalPage() {return totalPage;}public void setTotalPage(long totalPage) {this.totalPage = totalPage;}public long getPageNo() {return pageNo;}public void setPageNo(long pageNo) {this.pageNo = pageNo;}public List<?> getData() {return data;}public void setData(List<?> data) {this.data = data;}/*** 是否第⼀页*/public boolean isFirstPage() {return pageNo <= 1;}/*** 是否最后⼀页*/public boolean isLastPage() {return pageNo >= getTotalPage();}/*** 下⼀页页码*/public long getNextPage() {if (isLastPage()) {return pageNo;} else {return pageNo + 1;}}/*** 上⼀页页码*/public long getPrePage() {if (isFirstPage()) {return pageNo;} else {return pageNo - 1;}}public PageUtils(){}public PageUtils(long pageNo){this.pageNo=pageNo;}public PageUtils(long pageNo,long pageSize){this.pageNo=pageNo;this.pageSize = pageSize;}public List<?> getSumData() {return sumData;}public void setSumData(List<?> sumData) {this.sumData = sumData;}}查询的数据实体在查询的实体⾥添加页码和每页显⽰条数参数; private int pageSize; //每页显⽰的条数private int pageNo; //当前页码public int getPageSize() {return pageSize;}public void setPageSize(int pageSize) {this.pageSize = pageSize;}控制层Controller@RequestMapping("/list")public String list(Model model,ChannelValueInfoView input) {// input:传⼊的参数为对象PageUtils page=new PageUtils();//如果传⼊的当前条数为0,则赋予值(⾸次查询不带参);if(input.getPageSize()==0){//当前页码第⼀页input.setPageNo(1);//每页显⽰条数,当前每页显⽰10条数据;input.setPageSize(10);}page.setPageNo(input.getPageNo());page.setPageSize(input.getPageSize());//核⼼分页代码PageHelper p=new PageHelper();Page<ChannelValueInfoList> l=p.startPage(input.getPageNo(),input.getPageSize());//紧跟着的第⼀个select查询将会被分页channelValueService.getChannelValueInfoViewList(input);model.addAttribute("input", input);page.setData(l);page.setTotalCount(l.getTotal());model.addAttribute("page", page);return "index";}页⾯处理//循环穿过来的PAGE.data数据<tr th:each="ts : ${page.data}"><td th:text="${ts.channelValueName}"></td>----------<form id="content_form" action="/channelValue/list" method="post" ><div>总数:<span id="totalCount" th:text="${page.totalCount}">0</span></div><ul class="pagination"><li class="disabled"><a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" onclick="onFirst()">⾸页</a> </li><li class="disabled"><a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" onclick="onPre()"><</a> </li><li class="active"><a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><span id="beginRow" th:text="${page.pageNo}">0</span></a></li><li class="disabled"><a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" onclick="onNext()">></a> </li><li class="disabled"><a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" onclick="onLast()">尾页</a> </li></ul></for m>----------<script>function onFirst() {onList(1);}function onPre() {var beginRow = parseInt($('#beginRow').html());if (beginRow - 1 > 0) {onList(beginRow - 1);}}function onNext() {var beginRow = parseInt($('#beginRow').html());var totalCount = parseInt($('#totalCount').html());var pageSize = parseInt($('#pageSize').val());if (parseInt(totalCount / pageSize + 1) > beginRow + 1) {onList(beginRow+1);}}function onLast() {var totalCount = parseInt($('#totalCount').html());var pageSize = parseInt($('#pageSize').val());onList(parseInt(totalCount / pageSize + 1) - 1);}function onList(pageNo) {if (pageNo == 0)pageNo = 1;$('#pageNo').val(pageNo);$("#content_form").submit();}</script>以上就是本⽂的全部内容,希望对⼤家的学习有所帮助,也希望⼤家多多⽀持。
Java分页
Java分页1、分页原理分页必须两参数:页码即当前页为第⼏页(pageNo)、每页显⽰的记录数(pageSize)开始和结束位置:通过分页参数计算开始位置和结束位置,从⽽从列表中获取分页的数据。
开始和结束公式:Integer start = pageSize * (pageNo - 1); Integer end = pageSize * pageNo2、List分页截取/*** @Description List分页,获取每页数据* @param* @return*/public static void main(String[] args) {List<String> list = new ArrayList<>();list.add("1");list.add("2");list.add("3");list.add("4");list.add("5");//每页显⽰多⼩数据Integer pageSize = 2;//总页数Integer totalPage = list.size() / pageSize;//余数计算Integer mod = list.size() % pageSize;//如果有余数总页数+1if(mod > 0 ){totalPage = totalPage + 1;}//迭代取出每页内容for(int pageNo = 0;pageNo<totalPage;pageNo++){Integer start = pageSize * pageNo;Integer end = pageSize * (pageNo + 1);//避免超出列表最⼤界if(end > list.size()){end = list.size();}System.out.println("start:"+start+",end:"+end);List<String> subList = list.subList(start,end);System.out.println(StringUtils.join(subList,","));}}。
java封装分页方法
java封装分页方法在Java中,封装分页方法可以使代码更加清晰和可维护。
以下是一个简单的示例,演示如何封装分页方法:```javaimport ;public class PaginationUtil {/封装分页查询方法param list 数据列表param pageIndex 页码,从1开始param pageSize 每页数据量return 分页数据列表/public static List<Object> getPageData(List<Object> list, int pageIndex, int pageSize) {int start = (pageIndex - 1) pageSize;int end = start + pageSize;if (start < 0 end > ()) {return null;} else {return (start, end);}}}```在上面的代码中,我们定义了一个名为`PaginationUtil`的类,其中包含一个名为`getPageData`的静态方法。
该方法接受三个参数:数据列表、页码和每页数据量。
它使用Java的`subList`方法来获取指定范围内的数据列表,并返回该范围内的数据。
如果页码无效,则返回`null`。
使用该方法时,只需将要分页的数据列表、页码和每页数据量作为参数传递给该方法即可。
例如:```javaList<User> userList = (); // 获取所有用户数据列表List<User> pageData = (userList, 2, 10); // 分页查询第2页,每页10条记录```。
java的分页原理详解
java的分页原理详解⾸先先创建⼀个Student实体类。
import java.io.Serializable;import java.util.Map;public class Student implements Serializable {//实现序列化接⼝,⽤于对象的持久化private static final long serialVersionUID = -7476381137287496245L;//学⽣记录idprivate int id;//学⽣姓名private String stuName;//学⽣年龄private int age;//学⽣性别private int gender;//学⽣住址private String address;//空构造器public Student() {super();}/*** 构造器* @param id 学⽣记录id* @param stuName 学⽣姓名* @param age 学⽣年龄* @param gender 学⽣性别* @param address 学⽣住址*/public Student(int id, String stuName, int age, int gender, String address) {super();this.id = id;this.stuName = stuName;this.age = age;this.gender = gender;this.address = address;}/*** 该构造器⽤于将Map中的数据封装到Student类中,* 在构造器中传⼊Map参数。
* @param map*/public Student(Map<String, Object> map){this.id = (Integer)map.get("id");this.stuName = (String)map.get("stu_name");this.age = (Integer)map.get("age");this.gender = (Integer)map.get("gender");this.address = (String)map.get("address");}/** Getter Setter⽅法*/public int getId() {return id;}public void setId(int id) {this.id = id;}public String getStuName() {return stuName;}public void setStuName(String stuName) {this.stuName = stuName;}public int getAge() {return age;}public void setAge(int age) {this.age = age;}public int getGender() {return gender;}public void setGender(int gender) {this.gender = gender;}public String getAddress() {return address;}public void setAddress(String address) {this.address = address;}/** 重写toString⽅法* @see ng.Object#toString()*/@Overridepublic String toString() {return "Student [id=" + id + ", stuName=" + stuName + ", age=" + age+ ", gender=" + gender + ", address=" + address + "]";}}创建Pager类import java.io.Serializable;import java.util.List;public class Pager<T> implements Serializable {//实现序列化接⼝⽤于对象持久化private static final long serialVersionUID = -8741766802354222579L;// 每页显⽰多少条记录private int pageSize;//当前第⼏页数据private int currentPage;// ⼀共多少条记录private int totalRecord;// ⼀共多少页记录private int totalPage;//要显⽰的数据private List<T> dataList;//构造函数public Pager(int pageNum, int pageSize, List<T> sourceList){//如果数据源为空跳出该构造⽅法if(sourceList == null || sourceList.isEmpty()){return;}// 总记录条数等于数据源的长度this.totalRecord = sourceList.size();// 每页显⽰多少条记录this.pageSize = pageSize;//获取最⼤页数所有记录除以每页显⽰的条数this.totalPage = this.totalRecord / this.pageSize;if(this.totalRecord % this.pageSize !=0){this.totalPage = this.totalPage + 1;}// 当前第⼏页数据如果参数pageNum超过最⼤页数this.currentPage = this.totalPage < pageNum ? this.totalPage : pageNum;// 起始索引int fromIndex = this.pageSize * (this.currentPage -1);// 结束索引int toIndex = this.pageSize * this.currentPage > this.totalRecord ? this.totalRecord : this.pageSize * this.currentPage;this.dataList = sourceList.subList(fromIndex, toIndex);}//空构造器public Pager(){}//构造器public Pager(int pageSize, int currentPage, int totalRecord, int totalPage,List<T> dataList) {super();this.pageSize = pageSize;this.currentPage = currentPage;this.totalRecord = totalRecord;this.totalPage = totalPage;this.dataList = dataList;}/** Getter 和 Setter ⽅法*/public int getPageSize() {return pageSize;}public void setPageSize(int pageSize) {this.pageSize = pageSize;}public int getCurrentPage() {return currentPage;}public void setCurrentPage(int currentPage) {this.currentPage = currentPage;}public int getTotalRecord() {return totalRecord;}public void setTotalRecord(int totalRecord) {this.totalRecord = totalRecord;}public int getTotalPage() {return totalPage;}public void setTotalPage(int totalPage) {this.totalPage = totalPage;}public List<T> getDataList() {return dataList;}public void setDataList(List<T> dataList) {this.dataList = dataList;}}创建⼀个常量Constant类public class Constant {/*** 男性*/public static final int GENDER_MALE = 1;/*** ⼥性*/public static final int GENDER_FEMALE = 2;/*** 默认每页显⽰多少条记录*/public static final int DEFAULT_PAGE_SIZE = 5; /*** 默认显⽰第⼏页记录*/public static final int DEFAULT_PAGE_NUM = 1; /*** 默认学⽣性别*/public static final int DEFAULT_GENDER = 0;}创建StudentDAO类public interface StudentDao {/*** 根据查询条件,查询学⽣分页信息** @param searchModel* 封装查询条件* @param pageNum* 查询第⼏页数据* @param pageSize* 每页显⽰多少条记录* @return查询结果*/public Pager<Student> findStudent(Student searchModel, int pageNum,int pageSize);}创建⼀个JdbcUtil⼯具类public class JdbcUtil {// 表⽰定义数据库的⽤户名private static String USERNAME ;// 定义数据库的密码private static String PASSWORD;// 定义数据库的驱动信息private static String DRIVER;// 定义访问数据库的地址private static String URL;// 定义数据库的链接private Connection connection;// 定义sql语句的执⾏对象private PreparedStatement pstmt;// 定义查询返回的结果集合private ResultSet resultSet;static{//加载数据库配置信息,并给相关的属性赋值loadConfig();}/*** 加载数据库配置信息,并给相关的属性赋值* 从项⽬的jdbc.properties⽂件读取信息* 然后设置连接参数*/public static void loadConfig() {try {InputStream inStream = JdbcUtil.class.getResourceAsStream("/jdbc.properties");Properties prop = new Properties();prop.load(inStream);USERNAME = prop.getProperty("ername");PASSWORD = prop.getProperty("jdbc.password");DRIVER= prop.getProperty("jdbc.driver");URL = prop.getProperty("jdbc.url");} catch (Exception e) {throw new RuntimeException("读取数据库配置⽂件异常!", e);}}public JdbcUtil() {}/*** 获取数据库连接** @return数据库连接*/public Connection getConnection() {try {Class.forName(DRIVER); // 注册驱动connection = DriverManager.getConnection(URL, USERNAME, PASSWORD); // 获取连接 } catch (Exception e) {throw new RuntimeException("get connection error!", e);}return connection;/*** 执⾏更新操作** @param sql* sql语句* @param params* 执⾏参数* @return执⾏结果* @throws SQLException*/public boolean updateByPreparedStatement(String sql, List<?> params) throws SQLException {boolean flag = false;int result = -1;// 表⽰当⽤户执⾏添加删除和修改的时候所影响数据库的⾏数 pstmt = connection.prepareStatement(sql);int index = 1;// 填充sql语句中的占位符依次填⼊预处理语句所需的参数if (params != null && !params.isEmpty()) {for (int i = 0; i < params.size(); i++) {pstmt.setObject(index++, params.get(i));}}result = pstmt.executeUpdate();flag = result > 0 ? true : false;return flag;}/*** 执⾏查询操作** @param sql* sql语句* @param params* 执⾏参数* @return* @throws SQLException*/public List<Map<String, Object>> findResult(String sql, List<?> params) throws SQLException {//创建泛型为Map类型的ListList<Map<String, Object>> list = new ArrayList<Map<String, Object>>();//预处理语句参数索引int index = 1;pstmt = connection.prepareStatement(sql);//依次填⼊参数if (params != null && !params.isEmpty()) {for (int i = 0; i < params.size(); i++) {pstmt.setObject(index++, params.get(i));}}//执⾏预处理语句获得结果集resultSet = pstmt.executeQuery();//获取源数据ResultSetMetaData metaData = resultSet.getMetaData();//获取源数据的条数int cols_len = metaData.getColumnCount();//遍历resultSet将数据放⼊map中再将map放⼊list中while (resultSet.next()) {Map<String, Object> map = new HashMap<String, Object>();for (int i = 0; i < cols_len; i++) {String cols_name = metaData.getColumnName(i + 1);Object cols_value = resultSet.getObject(cols_name);if (cols_value == null) {cols_value = "";}map.put(cols_name, cols_value);}list.add(map);}return list;}/*** 释放资源*/public void releaseConn() {if (resultSet != null) {try {resultSet.close();} catch (SQLException e) {e.printStackTrace();}if (pstmt != null) {try {pstmt.close();} catch (SQLException e) {e.printStackTrace();}}if (connection != null) {try {connection.close();} catch (SQLException e) {e.printStackTrace();}}}}创建JdbcSqlStudentDaoImpl类/*** 使⽤mysql数据库limit关键字实现分页****/public class JdbcSqlStudentDaoImpl implements StudentDao {//实现查询的⽅法@Overridepublic Pager<Student> findStudent(Student searchModel, int pageNum,int pageSize) {//存放获取的数据Pager<Student> result = null;// 存放查询参数List<Object> paramList = new ArrayList<Object>();//获取查询参数NameString stuName = searchModel.getStuName();//获取查询参数genderint gender = searchModel.getGender();//创建查询语句StringBuilder sql = new StringBuilder("select * from t_student where 1=1");//得到所有的记录条数StringBuilder countSql = new StringBuilder("select count(id) as totalRecord from t_student where 1=1 ");//如果stuName存在且不为空的话在两条sql语句后⾯加上查询条件if (stuName != null && !stuName.equals("")) {sql.append(" and stu_name like ?");countSql.append(" and stu_name like ?");//查询条件放⼊查询参数集合中paramList.add("%" + stuName + "%");}//如果gender的值等于两个常量中的其中⼀个时if (gender == Constant.GENDER_FEMALE || gender == Constant.GENDER_MALE) {sql.append(" and gender = ?");countSql.append(" and gender = ?");paramList.add(gender);}// 起始索引int fromIndex = pageSize * (pageNum -1);// 使⽤limit关键字,实现分页sql.append(" limit " + fromIndex + ", " + pageSize );// 存放所有查询出的学⽣对象List<Student> studentList = new ArrayList<Student>();//创建JDBC⼯具类JdbcUtil jdbcUtil = null;try {jdbcUtil = new JdbcUtil();// 获取数据库链接jdbcUtil.getConnection();// 获取总记录数List<Map<String, Object>> countResult = jdbcUtil.findResult(countSql.toString(), paramList);//获取List中的第⼀个MapMap<String, Object> countMap = countResult.get(0);//获取Map中的键值为totalRecord的值int totalRecord = ((Number)countMap.get("totalRecord")).intValue();// 获取查询的学⽣记录List<Map<String, Object>> studentResult = jdbcUtil.findResult(sql.toString(), paramList);//将Map中的数据遍历出来封装成student类再放⼊studentlist中去if (studentResult != null) {for (Map<String, Object> map : studentResult) {Student s = new Student(map);studentList.add(s);}}//获取总页数int totalPage = totalRecord / pageSize;if(totalRecord % pageSize !=0){totalPage++;}// 组装pager对象result = new Pager<Student>(pageSize, pageNum,totalRecord, totalPage, studentList);} catch (SQLException e) {throw new RuntimeException("查询所有数据异常!", e);} finally {if (jdbcUtil != null) {jdbcUtil.releaseConn(); // ⼀定要释放资源}}return result;}}创建service类public interface StudentService {/*** 根据查询条件,查询学⽣分页信息** @param searchModel* 封装查询条件* @param pageNum* 查询第⼏页数据* @param pageSize* 每页显⽰多少条记录* @return查询结果*/public Pager<Student> findStudent(Student searchModel, int pageNum,int pageSize);}创建Servlet类public class JdbcSqlServlet extends HttpServlet {private static final long serialVersionUID = -318134993070614515L;private StudentService studentService = new JdbcSqlStudentServiceImpl();public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {doPost(request, response);}public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {// 接收request⾥的参数String stuName = request.getParameter("stuName"); //学⽣姓名// 获取学⽣性别//如果没有获取到就赋值为默认数值int gender = Constant.DEFAULT_GENDER;String genderStr = request.getParameter("gender");//如果符合条件就转化为Int类型if(genderStr!=null && !"".equals(genderStr.trim())){gender = Integer.parseInt(genderStr);}// 校验pageNum参数输⼊合法性String pageNumStr = request.getParameter("pageNum");//如果页码数不是数字的话if(pageNumStr !=null && !StringUtil.isNum(pageNumStr)){request.setAttribute("errorMsg", "参数传输错误");request.getRequestDispatcher("jdbcSqlStudent.jsp").forward(request, response);return;}//显⽰第⼏页数据int pageNum = Constant.DEFAULT_PAGE_NUM;//获取页码数if(pageNumStr!=null && !"".equals(pageNumStr.trim())){pageNum = Integer.parseInt(pageNumStr);}int pageSize = Constant.DEFAULT_PAGE_SIZE; // 每页显⽰多少条记录String pageSizeStr = request.getParameter("pageSize");if(pageSizeStr!=null && !"".equals(pageSizeStr.trim())){pageSize = Integer.parseInt(pageSizeStr);}// 组装查询条件Student searchModel = new Student();searchModel.setStuName(stuName);searchModel.setGender(gender);//调⽤service 获取查询结果Pager<Student> result = studentService.findStudent(searchModel,pageNum, pageSize);// 返回结果到页⾯request.setAttribute("result", result);request.setAttribute("stuName", stuName);request.setAttribute("gender", gender);request.getRequestDispatcher("jdbcSqlStudent.jsp").forward(request, response); }}加上⼀个正则⼯具类⽤于判断输⼊的参数是否为数字public class StringUtil {/*** 校验字符串是否是⼤于0的数字* @param string* @return*/public static boolean isNum(String string){Pattern pattern = pile("[1-9]{1}\\d*");Matcher matcher = pattern.matcher(string);return matcher.matches();}}。
Java之mybatis使用limit实现分页案例讲解
Java之mybatis使⽤limit实现分页案例讲解1. Limit实现分页1.1 为什么需要分页减少数据的处理量1.2 使⽤Limit实现分页select * from user limit startIndex,pageSize; # 注意是从startIndex+1开始查询 pageSize 个select * from user limit 3; # [0,3]1.3 使⽤mybatis实现分页(核⼼:SQL)1.3.1 接⼝UserMapper.java// limit实现分页 Map后⾯只能是 Integer 包装类不可以 intList<User> getUserByLimit(Map<String, Integer> map);1.3.2 UserMapper.xml<select id="getUserByLimit" resultMap="er" parameterType="map">select *from erlimit #{statrIndex},#{pageSize};</select>1.3.3 测试类UserMapperTest.java<select id="getUserByLimit" resultMap="UserMap" parameterType="map">select *from `mybatis`.`user`limit #{startIndex},#{pageSize};</select><select id="getUserById" resultMap="UserMap">select *from `mybatis`.`user`where id = #{id};</select>执⾏结果:到此这篇关于Java之mybatis使⽤limit实现分页案例讲解的⽂章就介绍到这了,更多相关Java之mybatis使⽤limit实现分页内容请搜索以前的⽂章或继续浏览下⾯的相关⽂章希望⼤家以后多多⽀持!。
java分页原理及实现方式
Java分页原理及常用分页方法什么是分页技术分页,是一种将所有数据分段展示给用户的技术.用户每次看到的不是全部数据,而是其中的一部分。
如果在其中没有找到自习自己想要的内容,用户可以通过制定页码或是翻页的方式转换可见内容,直到找到自己想要的内容为止.其实这和我们阅读书籍很类似,我们不能把整本书的全部内容写在一页纸上。
为什么要分页?1、加载少量数据,减少客户的和服务器数据交互,降低服务器压力。
2、增强用户体验,每次加载数据量少,加载速度自然就快,用户体验就好。
常见分页样式:1、传统分页(分页工具栏),如百度的分页:2、自动加载:如QQ空间下拉自动加载数据传统分页与下拉式分页对比传统分页可以明确数据信息,数量等;下拉式无法明确数据量等信息,分页后之前从信息还在页面上。
常见分页实现方式1.Java程序分页的实现主要是用List 接口中的subList(int startIndex,int endIndex)方法,这种方式也称为程序内存分页。
2.使用数据库的SQL语句实现数据分页。
适用于数据量较大,访问频度较低的操作。
如果数据量大,访问频度又高,可以参考大数据分页。
关于内存分页当数据量较小时推荐使用。
使用subList进行分页时,如果数据量比较大是一个非常耗费系统资源的方案。
目前web项目有许多分布式系统,可能有多个系统访问同一个数据库,那么对数据库的开销就比较大了,这时可以考虑对内存分页进行优化,例如利用程序缓存处理机制等。
精选文库其实真正的内存分页不是那么简单的事情,要实现一个完整的通用的机制,不是一两个小时就能搞定的。
首先有一个数据记录的服务器缓存问题,然后才是数据记录分页问题,这个相对好解决一点,但第一个问题就不太好组织。
因为缓存问题涉及到数据的缓存位置,缓存时间,删除时间和利于查询的数据组织问题。
数据库分页:数据库分页的原理比较明确了,根据需要取结果集中的一部分就是了,没什么好说的。
其实这样有时候数据缓存在数据库系统内,可能比内存分页要智能一点。
java分页查询原理思路
java分页查询原理思路
在Java应用中,分页操作是常见而且十分必要的一项
基本操作,其任务主要是将大量数据按照指定大小分割成不同的块来减轻数据传输等运算压力,因此,对于现代信息处理系统是必不可少的技术手段之一。
要实现Java分页查询,首先要确定分页的大小,该值
决定了一次返回的数据量,而根据需要设置当前为第几页来控制需要获取哪些数据。
具体步骤为:首先,向数据库查询数据总条数,然后计算出一共可以分多少页;接着,使用分页所涉及的属性(比如每页大小,当前页码等),计算出本页起始位置和结束位置;接着,根据计算出来的位置,通过sql语句查询,拉取本页所需要的数据;最后,将查询结果封装,作为返回结果返回。
以上就是Java实现分页查询的原理思路,实际实现中,需要注意分页大小的设置,尽量保证每次查询的数据量适中,提高查询效率,另外,当所有数据量比较小时,可以放弃分页,直接一次查出全部数据,可以大大节省
查询操作。
总而言之,Java分页查询不仅能有效降低数据量,还能大幅度提高查询效率,是必不可少的重要技术手段。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
import er; import erpage;
public class UserPage { ConnectionDB cdb=new ConnectionDB(); public List<User> getUser(User user) { List<User> list=new ArrayList<User>(); Connection conn=cdb.conn();//连接数据库 try { Statement stmt=conn.createStatement(); ResultSet rs=stmt.executeQuery("select * from login"); while(rs.next()) { User u=new User(); u.setPassword(rs.getString("password")); u.setUsename(rs.getString("usename")); u.setId(rs.getInt("id")); list.add(u); } } catch (SQLException e) { e.printStackTrace(); } finally{ try { conn.close(); } catch (SQLException e) { e.printStackTrace(); } } return list; } public List<User> getPage(int nowpage,List<User> listall) { List<User> list=new ArrayList<User>(); int mun=10;//每页的条数 int pagetotal=0;//总页数
河南大学软件学院
pagetotal=listall.size()/mun+1; //System.out.println(pagetotal+"\t"+listall.size()%10); if(pagetotal==nowpage) {
mun=listall.size()%mun; } // System.out.println(mun); for(int i=0;i<mun;i++) {
} }
三、执行 action package com.neusoft.action;
import java.util.ArrayList; import java.util.List;
import javax.servlet.http.HttpServletRequest;
import org.apache.struts2.ServletActionContext;
Userpage userpage=upage.get(i); System.out.println("第"+userpage.getMun()+"页"); for(int j=0;j<userpage.getList().size();j++) {
User use=userpage.getList().get(j); System.out.println(use.getPassword()+"\t"+use.getUsename()); } }
//执行显示得到的数据集的首页 listuser=up.getPage(nowPage, list);
return "success"; } public String getlistnext() {
//显示下一页数据集
河南大学软件学院
HttpServletRequest request=ServletActionContext.getRequest(); nowPage=Integer.parseInt(request.getParameter("nowPage"))+1; System.out.println(nowPage); if(nowPage>pagetotal) nowPage=1; listuser=up.getPage(nowPage, list);
import java.sql.Connection;
河南大学软件学院
import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import java.util.ArrayList; import java.util.List;
super(); ename=usename; this.password=password; this.id=id; } public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getUsename() { return usename; } public void setUsename(String usename) { ename = usename; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } public User() { super(); } } 二、得到数据集 package mon;
import erPage; import er; import erpage;
河南大学软件学院
public class PageoneAction { public User getUser() { return user; } public void setUser(User user) { er = user; } public Integer getNowPage() { return nowPage; } public void setNowPage(Integer nowPage) { this.nowPage = nowPage; } public Integer getPagetotal() { return pagetotal; } public void setPagetotal(Integer pagetotal) { this.pagetotal = pagetotal; } public List<User> getListuser() { return listuser; } public void setListuser(List<User> listuser) { this.listuser = listuser; }
河南大学软件学院
关于分页的简单案例
关于分页的问题,此案例只是个人思想实现的分页。在编程中,没有实现不了的功能, 只有想出Байду номын сангаас的执行过程,简单的实现学习分页的基础思想。 一、User 类
public class User { private String usename; private String password; private Integer id; public User(String usename,String password,Integer id) {
User use=listall.get((nowpage-1)*10+i); list.add(use); } return list; } public List<Userpage> getUserPage(List<User> listall){ List<Userpage> upage=new ArrayList<Userpage>();
UserPage userpage=new UserPage(); for(int i=0;i<listall.size()/10+1;i++) {
Userpage up=new Userpage(); List<User> list=userpage.getPage(i+1, listall); up.setMun(i+1); up.setList(list); upage.add(up); } return upage; } public void insertUser(User user) { Connection conn=cdb.conn();//连接数据库 try { PreparedStatement pstm=conn.prepareStatement("insert into login (usename,password) values(?,?)"); pstm.setString(1,user.getUsename()); pstm.setString(2,user.getPassword()); pstm.execute(); } catch (SQLException e) { e.printStackTrace(); } finally{ try {