Oracle使用MyBatis中RowBounds實現分頁查詢功能
阿新 • • 發佈:2020-01-09
Oracle中分頁查詢因為存在偽列rownum,sql語句寫起來較為複雜,現在介紹一種通過使用MyBatis中的RowBounds進行分頁查詢,非常方便。
使用MyBatis中的RowBounds進行分頁查詢時,不需要在 sql 語句中寫 offset,limit,mybatis 會自動拼接 分頁sql ,新增 offset,limit,實現自動分頁。
需要前臺傳遞引數currentPage和pageSize兩個引數,分別是當前頁和每頁數量,controller層把引數傳遞給service層即可,下面是service實現的程式碼:
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 Map<String,Object> queryUserList(String currentPage,String pageSize) { //查詢資料總條數 int total = userDao.queryCountUser(); //返回結果集 Map<String,Object> resultMap = new HashMap<String,Object>(); resultMap.put("total",total); //總頁數 int totalpage = (total + Integer.parseInt(pageSize) - 1) / Integer.parseInt(pageSize); resultMap.put("totalpage",totalpage); //資料的起始行 int offset = (Integer.parseInt(currentPage)-1)*Integer.parseInt(pageSize); RowBounds rowbounds = new RowBounds(offset,Integer.parseInt(pageSize)); //使用者資料集合 List<Map<String,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(); //查詢使用者總數 public List<Map<String,Object>> queryUserList(RowBounds rowbounds); //查詢使用者列表 }
對應的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"> <!-- 查詢使用者總數 --> <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呼叫介面,傳入對應的引數,即可實現分頁查詢資料。
總結
以上所述是小編給大家介紹的Oracle使用MyBatis中RowBounds實現分頁查詢功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回覆大家的。在此也非常感謝大家對我們網站的支援!
如果你覺得本文對你有幫助,歡迎轉載,煩請註明出處,謝謝!