sql 分页加载数据

首先,我们需要写一条sql语句,每次查询多少条数据

<!-- 分页 -->
    <select id="articlePageList" resultType="Article">
        SELECT
        a.id AS "id",
        a.category_id AS "category.id",
        a.title AS "title",
        a.create_date AS "createDate"     // 上面这四个是我们需要的查出来的参数
        FROM cms_article a      
        WHERE
        a.category_id = #{cid}  // cid:传入的参数条件
        AND a.del_flag = 0
        ORDER BY a.weight DESC, a.create_date DESC
        LIMIT #{pageNo}, #{pageSize}  // pageNo:当前页   pageSize:每页显示多少条数据
    </select>

另外,我们还需要一条sql语句来查询相关条件的总条数

 <!--查询文章总条数 count-->
    <select id="totalCount" resultType="Article">
        SELECT *
        FROM cms_article a
        WHERE
        a.category_id = #{cid}
        AND  a.del_flag = 0
    </select>

接下来,我们需要去dao层

    // 查询条数
    public List<Article> totalCount(String cid);
    // 根据栏目id 当前页 条数 查询文章列表
    public List<Article> articlePageList(@Param("pageNo") int pageNo, @Param("pageSize") int pageSize, @Param("cid") String cid);

service层

    // 查询条数
    public List<Article> totalCount(String cid) {
        return articleDao.pageCount(cid);
    }

    // 根据栏目id 当前页 条数 查询文章列表
    public List<Article> articlePageList(int pageNo, int pageSize, String cid) {
        // 计算当前页 
        pageNo = pageNo - 1;
        pageNo = pageNo * pageSize;
        return articleDao.articlePageList(pageNo, pageSize, cid);
    }

    // 返回一个文章总数
    public int totalCounts(String cid) {
        // 文章总条数
        List<Article> articleCount = pageCount(cid);
        int totalCount = articleCount.size();
        return totalCounts;
    }

下面我是用接口来写的,在前段用ajax直接调用这个接口

    @RequestMapping(value = "findArticleList")
    @ResponseBody
    public Map<String, Object> findArticleList(String cid, String pageNo) {
        Map<String, Object> articleListMap = new HashMap<String, Object>();
        // 每页文章条数
        String pageSize = "10";
        List<Article> articlePage = articleService.articlePageList(Integer.parseInt(pageNo), Integer.parseInt(pageSize), cid);
        articleListMap.put("articlePage", articlePage);
        // 文章页数
        int totalCount = articleService.totalCount(cid);
        articleListMap.put("totalCount", totalCount);
        
        return articleListMap;
    }

我把ajax调用接口单独写在一个js文件

function articleListApi(cid, pageNo) {

    $.ajax({
        url: artlistUrl,
        type: 'post',
        dataType: 'json',
        data: {
            // 这里是将参数传到后台
            cid: cid,
            pageNo: pageNo,
        },
        success: function (data) {
            $("#artLis").html("");
            var list = data["articlePage"];
            var totalCount = data["totalCount"];
            getCount(totalCount);
            if (list == "undefined" || list == null || list == "") {
                $("#pageDiv").hide();
            } else {
                for (var i = 0; i < list.length; i++) {
                    var month = list[i].createDate.substring(5, 7);
                    var day = list[i].createDate.substring(8, 10);
                    $("#artLis").append("<li><a href='articleDetail?cid=" + list[i].category.id + "&id=" + list[i].id + "'><span>" + list[i].title + "</span><span class='fr'>" + month + "月" + day + "日</span></a></li>");
                }
                $("#pageDiv").show();
            }
        }
    });


}
// 从接口方法获取数据总数的方法
function getCount(totalCount) {
    pageClik(totalCount);
}

下面这里是在jsp页面写的调用方法

// 这个是我放在页面的一个隐藏标签,用来接收链接跳转过来的ID,也就是cid,需要把这个参数拿到传给后台接口
<input id="liCid" type="hidden" value="${param.cid}"/>
        <%-- 分页插件--%>
         // maxshowpageitem="5"  这个参数为显示的页码数  pagelistcount="10"   这个参数为每页显示多少条数据
        <div id="pageDiv">
            <div>
                <ul class="page" maxshowpageitem="5" pagelistcount="10" id="page"></ul>
            </div>
        </div>
---------------------------------------------------------------------
// 接口调用的链接地址
var artlistUrl = "${ctxf}/api/article/findArticleList";
$(document).ready(function () {
        // 拿到隐藏标签的值
        var cid = $("#liCid").val();
        // 第一次加载默认第一页
        var pageNo = 1;
        articleListApi(cid, pageNo);
    });

这个为分页插件的调用方法,也是写在jsp页面

<script type="text/javascript">
    var pageNo = 1;
    function pageClik(totalCount) {
        var cid = $("#liCid").val();
        var GG = {
            "kk": function (mm) {
              // 这里的 mm 为点击的第几页
                pageNo = mm;
            articleListApi(cid, pageNo);
            }
        }
        $("#page").initPage(totalCount, pageNo, GG.kk);
    }
</script>

下面直接贴出 分页的css文件,和分页的封装方法

.page {
    list-style: none;
}

.page > li {
    float: left;
    padding: 5px 10px;
    cursor: pointer;
}

.page .pageItem {
    border: solid thin #DDDDDD;
    margin: 5px;
}

.page .pageItemActive {
    border: solid thin #0099FF;
    margin: 5px;
    background-color: #0099FF;
    color: white;
}

.page .pageItem:hover {
    border: solid thin #0099FF;
    background-color: #0099FF;
    color: white;
}

.page .pageItemDisable {
    border: solid thin #DDDDDD;
    margin: 5px;
    background-color: #DDDDDD;
}
/**
 * Created by lhs on 2017/9/6.
 */
$.fn.extend({
    "initPage": function (listCount, currentPage, fun) {
        var maxshowpageitem = $(this).attr("maxshowpageitem");
        if (maxshowpageitem != null && maxshowpageitem > 0 && maxshowpageitem != "") {
            page.maxshowpageitem = maxshowpageitem;
        }
        var pagelistcount = $(this).attr("pagelistcount");
        if (pagelistcount != null && pagelistcount > 0 && pagelistcount != "") {
            page.pagelistcount = pagelistcount;
        }

        var pageId = $(this).attr("id");
        page.pageId = pageId;
        if (listCount < 0) {
            listCount = 0;
        }
        if (currentPage <= 0) {
            currentPage = 1;
        }
        page.setPageListCount(pageId, listCount, currentPage, fun);

    }
});
var page = {
    "maxshowpageitem": 5,//最多显示的页码个数
    "pagelistcount": 10,//每一页显示的内容条数
    /**
     * 初始化分页界面
     * @param listCount 列表总量
     */
    "initWithUl": function (pageId, listCount, currentPage) {

        var pageCount = 1;
        if (listCount > 0) {
            var pageCount = listCount % page.pagelistcount > 0 ? parseInt(listCount / page.pagelistcount) + 1 : parseInt(listCount / page.pagelistcount);
        }
        var appendStr = page.getPageListModel(pageCount, currentPage);
        $("#" + pageId).html(appendStr);
    },
    /**
     * 设置列表总量和当前页码
     * @param listCount 列表总量
     * @param currentPage 当前页码
     */
    "setPageListCount": function (pageId, listCount, currentPage, fun) {
        listCount = parseInt(listCount);
        currentPage = parseInt(currentPage);
        page.initWithUl(pageId, listCount, currentPage);
        page.initPageEvent(pageId, listCount, fun);

    },
    "initPageEvent": function (pageId, listCount, fun) {
        $("#" + pageId + ">li[class='pageItem']").on("click", function () {
            if (typeof fun == "function") {
                fun($(this).attr("page-data"));
            }
            page.setPageListCount(pageId, listCount, $(this).attr("page-data"), fun);
        });
    },
    "getPageListModel": function (pageCount, currentPage) {
        var prePage = currentPage - 1;
        var nextPage = currentPage + 1;
        var prePageClass = "pageItem";
        var nextPageClass = "pageItem";
        if (prePage <= 0) {
            prePageClass = "pageItemDisable";
        }
        if (nextPage > pageCount) {
            nextPageClass = "pageItemDisable";
        }
        var appendStr = "";
        appendStr += "<li class='" + prePageClass + "' page-data='1' page-rel='firstpage'>首页</li>";
        appendStr += "<li class='" + prePageClass + "' page-data='" + prePage + "' page-rel='prepage'><上一页</li>";
        var miniPageNumber = 1;
        if (currentPage - parseInt(page.maxshowpageitem / 2) > 0 && currentPage + parseInt(page.maxshowpageitem / 2) <= pageCount) {
            miniPageNumber = currentPage - parseInt(page.maxshowpageitem / 2);
        } else if (currentPage - parseInt(page.maxshowpageitem / 2) > 0 && currentPage + parseInt(page.maxshowpageitem / 2) > pageCount) {
            miniPageNumber = pageCount - page.maxshowpageitem + 1;
            if (miniPageNumber <= 0) {
                miniPageNumber = 1;
            }
        }
        var showPageNum = parseInt(page.maxshowpageitem);
        if (pageCount < showPageNum) {
            showPageNum = pageCount
        }
        for (var i = 0; i < showPageNum; i++) {
            var pageNumber = miniPageNumber++;
            var itemPageClass = "pageItem";
            if (pageNumber == currentPage) {
                itemPageClass = "pageItemActive";
            }

            appendStr += "<li class='" + itemPageClass + "' page-data='" + pageNumber + "' page-rel='itempage'>" + pageNumber + "</li>";
        }
        appendStr += "<li class='" + nextPageClass + "' page-data='" + nextPage + "' page-rel='nextpage'>下一页></li>";
        appendStr += "<li class='" + nextPageClass + "' page-data='" + pageCount + "' page-rel='lastpage'>尾页</li>";
        return appendStr;

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

推荐阅读更多精彩内容