java如何调取数据库中的数据,(java怎么调用数据库)

java如何调取数据库中的数据,(java怎么调用数据库),第1张

假设一共有31条总记录数
现在要显示每页10行
那么如果直接除的话 31/10=31页,也就是3页,那第四页的1行就不见了
假设总记录数=(31+10-1)/10=4页,所以符合要求
为什么要10-1呢?
假设,我们的总记录数是30,每页显示10行,那么3页就可以了,
如果(30+10)/10=4页了,得到的页数就是错误的,所以
每页行数-1其实就是判断,行数要小于当前设定的行数

page类
public class PageModel {
private int totalCount = 0;// 总记录数
private int pageCount;// 总页数
private int pageSize = 10;// 每页显示记录数
private int page = 1;// 当前页
private int num = 5;// 当前页之前和之后显示的页数个数 如:假设当前页是 6 共有11页 那么 显示分页条会显示 1 2 3 4
// 5 [6] 7 8 9 10 11
@SuppressWarnings("unchecked")
private List items = new ArrayList();// 当前页记录内容集合
private int prev;// 前一页
private int next;// 后一页
private int last;// 最后一页
private List<Integer> prevPages;// 得到前num页的数据集合
private List<Integer> nextPages;// 得到后num页的数据集合
/
计算总页数

@param totalCount
/
public void setTotalCount(int totalCount) {
if (totalCount > 0) {
thistotalCount = totalCount;
thispageCount = (totalCount + pageSize - 1) / pageSize;
}
}
/
判断是否有前一页

@return boolean
/
public boolean getIsPrev() {
if (page > 1) {
return true;
}
return false;
}
/
获取前一页

@return int
/
public int getPrev() {
if (getIsPrev()) {
return page - 1;
} else {
return page;
}
}
/
判断是否有后一页

@return boolean
/
public boolean getIsNext() {
if (page < pageCount) {
return true;
}
return false;
}
/
获取后一页

@return int
/
public int getNext() {
if (getIsNext()) {
return page + 1;
}
return getPageCount();
}
/
获取最后一页

@return int
/
public int getLast() {
return pageCount;
}
/
当前页的前num条页 假设当前页是 6 共有11页 如:1 2 3 4 5

@return List<Integer>
/
public List<Integer> getPrevPages() {
List<Integer> list = new ArrayList<Integer>();
int _frontStart = 1;
if (page > num) {
_frontStart = page - num;
} else if (page <= num) {
_frontStart = 1;
}
for (int i = _frontStart; i < page; i++) {
listadd(i);
}
return list;
}
/
当前页的后num条页 假设当前页是 6 共有11页 如:7 8 9 10 11

@return List<Integer>
/
public List<Integer> getNextPages() {
List<Integer> list = new ArrayList<Integer>();
int _endCount = num;
if (num < pageCount && (page + num) < pageCount) {
_endCount = page + _endCount;
} else if ((page + num) >= pageCount) {
_endCount = pageCount;
}
for (int i = page + 1; i <= _endCount; i++) {
listadd(i);
}
return list;
}
/
获取每页显示记录数

@return int
/
public int getPageSize() {
return pageSize;
}
/
设置每页显示记录数

@param pageSize
/
public void setPageSize(int pageSize) {
thispageSize = pageSize;
}
/
得到当前页数

@return int
/
public int getPage() {
return page;
}
/
设置当前页数

@param page
/
public void setPage(int page) {
thispage = page;
}
/
获取当前页之前或之后显示的页数个数

@return int
/
public int getNum() {
return num;
}
/
设置当前页之前或之后显示的页数个数

@param num
/
public void setNum(int num) {
thisnum = num;
}
/
获取当前页记录内容集合

@return List
/
@SuppressWarnings("unchecked")
public List getItems() {
return items;
}
/
设置当前页记录内容集合

@param items
/
@SuppressWarnings("unchecked")
public void setItems(List items) {
thisitems = items;
}
/
获取总记录数

@return int
/
public int getTotalCount() {
return totalCount;
}
/
得到总页数

@return int
/
public int getPageCount() {
return pageCount;
}
}

action代码:
PageModel pageModel = new PageModel();
// 获得当前页
if (page != 0) {
pageModelsetPage(page);
}

pageModelsetPageSize(10);// 设置页面显示最大 值
pageModelsetTotalCount(baseDAOlistAll("from Art where arttypeid=10 and mark=0 order by id desc")); // 数据总条数
pageModelsetNum(5); // 设置当前页的前后距离,/前后各显示5页/
// 通过当前页和
List<Art> aboutList = baseDAOlistAll("from Art where arttypeid=10 and mark=0 order by id desc", pageModelgetPage(),pageModelgetPageSize());
pageModelsetItems(aboutList);
requestsetAttribute("count", aboutListsize());// 放置在request中
requestsetAttribute("pageModel", pageModel);
requestsetAttribute("page", pageModelgetPage());
jsp代码

<c:forEach var = "i" items="${requestScopepageModelitems}" varStatus="items">
<li></li>
</c:forEach>

<div class="badoo"><span class="disabled">第${pageModelpage}页/共${pageModelpageCount}页</span> <a href="${pageuri}&page=1">首页</a>
<c:if test="${pageModelpage>1}">
<a href="${pageuri}&page=${pageModelprev}">上一页</a>
</c:if>
<c:forEach var="pre" items="${pageModelprevPages }">
<a href="${pageuri}&page=${pre }">${pre}</a>
</c:forEach>
<span class="current">${pageModelpage }</span>
<c:forEach var="next" items="${pageModelnextPages }">
<a href="${pageuri}&page=${next }">${next}</a>
</c:forEach>
<c:if test="${pageModelpage<pageModellast}">
<a href="${pageuri}&page=${pageModelnext}">下一页</a>
</c:if>
<a href="${pageuri}&page=${pageModellast}">尾页</a></div>
如有不懂可以找我QQ聊


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/yw/13368323.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-07-23
下一篇 2023-07-23

发表评论

登录后才能评论

评论列表(0条)

保存