快速分页查询分页2018

(一) 封装一个bean方法

package com.seecen.ssm.pojo;

import java.util.List;

/**

* Author: CalcYu

* Date: 2018/5/18

*/

public class Page<A> {

    /**

    * 传递查询条件

    */

    private A condition;

    public A getCondition() {

        return condition;

    }

    public void setCondition(A condition) {

        this.condition = condition;

    }

    private List<A> list;

    public List<A> getList() {

        return list;

    }

    public void setList(List<A> list) {

        this.list = list;

    }

    /**

    * 某张表的总记录数

    */

    private Integer total;

    /**

    * 当前页数

    */

    private Integer currentPage = 1;

    /**

    * 每页显示多少条记录

    */

    private Integer pageSize = 10;

    /**

    * SQL分页的开始位置

    *

    * @return

    */

    public Integer getStart() {

        return (currentPage - 1) * pageSize;

    }

    /**

    * SQL分页的结束位置

    *

    * @return

    */

    public Integer getEnd() {

        return currentPage * pageSize;

    }

    public Integer getTotalPage() {

        return (int) Math.ceil(total * 1.0 / pageSize);

    }

    public Integer getTotal() {

        return total;

    }

    public void setTotal(Integer total) {

        this.total = total;

    }

    public Integer getCurrentPage() {

        return currentPage;

    }

    public void setCurrentPage(Integer currentPage) {

        this.currentPage = currentPage;

    }

    public Integer getPageSize() {

        return pageSize;

    }

    public void setPageSize(Integer pageSize) {

        this.pageSize = pageSize;

    }

}


(二)Service

/**

    * 创建一个订单

    * @return

    */

    public boolean addOrder(Order order);

    /**

    * 订单表的分页查询

    * @param page

    * @return

    */

    public Page findOrdersByPage(Page page);

《*》ServiceImpl

@Autowired

    private OrderMapper orderMapper;

    public boolean addOrder(Order order) {

        return orderMapper.insert(order) > 0;

    }

    public Page findOrdersByPage(Page page) {

        if(page!=null){

            page.setList(orderMapper.selectByExample(null));

            page.setTotal(orderMapper.countByExample(null));

            return page;

        }

        return null;

    }


(三)Controller

@RequestMapping("/list")

    public String list(Integer currentPage,Tclass tclass, Model model){

        Page<Tclass> page = new Page<Tclass>();

        if (currentPage!=null){

            page.setCurrentPage(currentPage);

        }

        if (tclass!=null){

            page.setCondition(tclass);

        }

        List<Tclass> list = tclassService.findByClassId();

        page = tclassService.findTclassByPage(page);

        model.addAttribute("l",list);

        model.addAttribute("p",page);

        return "classfond/list";

    }


//或者

@RequestMapping("")

    public String list(Model model) {

        Page<Order> page = new Page();

        page = orderService.findOrdersByPage(page);

        model.addAttribute("p", page);

        return "order/list";

    }



(四)jsp页面

<%@ page contentType="text/html;charset=UTF-8" language="java" %>

<html>

<head>

    <title>Title</title>

    <script src="/js/jquery-3.3.1.min.js"></script>

</head>

<body>

<div>

    <input id="crtPage" type="hidden" name="currentPage">

    <script>

        function go(currentPage) {

            $("#crtPage").val(currentPage);

            $("form").submit();

        }

    </script>

    <c:if test="${p.currentPage>1}">

        <a href="javascript:go(1)">首&nbsp;页</a>

        <a href="javascript:go(${p.currentPage-1})">上一页</a>

    </c:if>

    <c:if test="${p.currentPage==1}">

        <a href="javascript:void(0)" style="color: #666666">首&nbsp;页</a>

        <a href="javascript:void(0)"  style="color: #666666">上一页</a>

    </c:if>

    [${p.currentPage}/${p.totalPage}]

    <c:if test="${p.currentPage<p.totalPage}">

        <a href="javascript:go(${p.currentPage+1})">下一页</a>

        <a href="javascript:go(${p.totalPage})">末&nbsp;页</a>

    </c:if>

    <c:if test="${p.currentPage==p.totalPage}">

        <a href="javascript:void(0)" style="color: #666666">下一页</a>

        <a href="javascript:void(0)" style="color: #666666">末&nbsp;页</a>

    </c:if>

</div>

</body>

</html>

(HTML页面)

</tbody>

<!-- ajaxjieshu -->

<tfoot>

<tr>

<td colspan="5"><div onclick="daiban(1)" class="leftdiv">首页</div>

<div class="leftdiv" >上一页</div>

<div class="leftdiv"

onclick="daiban(parseInt($('#pageIndex').html())+1>parseInt($('#pageCount').html())?parseInt($('#pageCount').html()):parseInt($('#pageIndex').html())+1)">下一页</div>

<div class="leftdiv"

onclick="daiban(parseInt($('#pageCount').html()))">尾页</div>

当前第<font color="red" id="pageIndex">1</font>页/共<font

id="pageCount" color="red">0</font>页</td>

</tr>

</tfoot>

</table>

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

推荐阅读更多精彩内容

  • 一. Java基础部分.................................................
    wy_sure阅读 3,807评论 0 11
  • rljs by sennchi Timeline of History Part One The Cognitiv...
    sennchi阅读 7,312评论 0 10
  • 一. 常用预定义函数 二. 字符串操作1. 常用操作函数方法描述big()用大号字体显示字符串。blink()显示...
    一脸委屈样阅读 797评论 0 0
  • 2015已经过去,细节太多,不一一回忆,总得来说还是不错,又成熟了一些,更勇敢更坚定,心在变宽广,感觉自己更强大了...
    小牛橙阅读 317评论 0 2
  • 1,今天回学校的z,回来了。然后我和她说自己最近失眠了。会有黑眼圈的。 她说:没事儿,你脸本来就黑。 我:。。。。...
    264eec636ef7阅读 156评论 0 0