佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > Oracle使用MyBatis中RowBounds實現(xiàn)分頁查詢功能

Oracle使用MyBatis中RowBounds實現(xiàn)分頁查詢功能

熱門標簽:呼叫中心市場需求 AI電銷 服務(wù)外包 鐵路電話系統(tǒng) 百度競價排名 Linux服務(wù)器 地方門戶網(wǎng)站 網(wǎng)站排名優(yōu)化

Oracle中分頁查詢因為存在偽列rownum,sql語句寫起來較為復(fù)雜,現(xiàn)在介紹一種通過使用MyBatis中的RowBounds進行分頁查詢,非常方便。

使用MyBatis中的RowBounds進行分頁查詢時,不需要在 sql 語句中寫 offset,limit,mybatis 會自動拼接 分頁sql ,添加 offset,limit,實現(xiàn)自動分頁。

需要前臺傳遞參數(shù)currentPage和pageSize兩個參數(shù),分別是當前頁和每頁數(shù)量,controller層把參數(shù)傳遞給service層即可,下面是service實現(xiàn)的代碼:

package com.xyfer.service.impl;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.apache.ibatis.session.RowBounds;
import com.xyfer.dao.UserDao;
import com.xyfer.service.UserService;
public class UserServiceImpl implements UserService {
  private UserDao userDao;
  @Override
  public MapString, Object> queryUserList(String currentPage, String pageSize) {
    //查詢數(shù)據(jù)總條數(shù)
    int total = userDao.queryCountUser();
    //返回結(jié)果集
    MapString,Object> resultMap = new HashMapString,Object>();
    resultMap.put("total", total);
    //總頁數(shù)
    int totalpage = (total + Integer.parseInt(pageSize) - 1) / Integer.parseInt(pageSize);
    resultMap.put("totalpage", totalpage);
    //數(shù)據(jù)的起始行
    int offset = (Integer.parseInt(currentPage)-1)*Integer.parseInt(pageSize);
    RowBounds rowbounds = new RowBounds(offset, Integer.parseInt(pageSize));
    //用戶數(shù)據(jù)集合
    ListMapString, Object>> userList = userDao.queryUserList(rowbounds);
    resultMap.put("userList", userList);
    return resultMap;
  }
}

dao層接口:

package com.xyfer.dao;
import java.util.List;
import java.util.Map;
import org.apache.ibatis.session.RowBounds;
public interface UserDao {
  public int queryCountUser();    //查詢用戶總數(shù)
  public ListMapString, Object>> queryUserList(RowBounds rowbounds);  //查詢用戶列表
}

對應(yīng)的mapper.xml文件:

?xml version="1.0" encoding="UTF-8" ?>
!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
mapper namespace="com.xyfer.mapper.UserMapper">
  !-- 查詢用戶總數(shù) -->
  select id="queryCountUser" resultType="java.lang.Integer">
    select count(1) from user
  /select>
  !-- 查詢用戶列表 -->
  select id="queryUserList" resultType="java.util.Map">
    select * from user
  /select>
/mapper>

通過postman調(diào)用接口,傳入對應(yīng)的參數(shù),即可實現(xiàn)分頁查詢數(shù)據(jù)。

總結(jié)

以上所述是小編給大家介紹的Oracle使用MyBatis中RowBounds實現(xiàn)分頁查詢功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

您可能感興趣的文章:
  • mybatis中查詢結(jié)果為空時不同返回類型對應(yīng)返回值問題
  • 結(jié)合mybatis-plus實現(xiàn)簡單不需要寫sql的多表查詢
  • mybatis 實現(xiàn) SQL 查詢攔截修改詳解
  • 詳解MyBatis模糊查詢LIKE的三種方式
  • MyBatis帶參查詢的方法詳解

標簽:蘭州 銅川 衡水 崇左 仙桃 湖南 黃山 湘潭

巨人網(wǎng)絡(luò)通訊聲明:本文標題《Oracle使用MyBatis中RowBounds實現(xiàn)分頁查詢功能》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    观塘区| 建始县| 奎屯市| 页游| 隆化县| 东宁县| 临西县| 岳普湖县| 灵山县| 新闻| 郎溪县| 嘉峪关市| 宜黄县| 侯马市| 阿拉善左旗| 平泉县| 泸定县| 宽城| 碌曲县| 涟水县| 含山县| 邵阳县| 长汀县| 瑞金市| 丰县| 酉阳| 长丰县| 保德县| 泸溪县| 尉氏县| 彰武县| 错那县| 张家界市| 滦平县| 贺州市| 宁化县| 铜梁县| 顺平县| 石门县| 施甸县| 洛扎县|