1. 程式人生 > 資料庫 >Oracle使用MyBatis中RowBounds實現分頁查詢功能

Oracle使用MyBatis中RowBounds實現分頁查詢功能

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實現分頁查詢功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回覆大家的。在此也非常感謝大家對我們網站的支援!
如果你覺得本文對你有幫助,歡迎轉載,煩請註明出處,謝謝!