pagehelper自定义oracle分页逻辑

原先分页是

SELECT TMP_PAGE.*, ROWNUM PAGEHELPER_ROW_ID FROM

需改成

OFFSET ? ROWS FETCH FIRST ? ROWS ONLY

配置文件增加

pagehelper:
  helper-dialect: com.dd.oss.common.datasource.mybatis.AS400Dialect

增加类 AS400Dialect,这个高版本会有的,不用新增这个类了。5.2.0版本无,5.3.1才增加的版本

package com.dd.oss.common.datasource.mybatis;

import com.github.pagehelper.Page;
import com.github.pagehelper.dialect.AbstractHelperDialect;
import org.apache.ibatis.cache.CacheKey;
import org.apache.ibatis.mapping.BoundSql;
import org.apache.ibatis.mapping.MappedStatement;

import java.util.Map;

/**
 * @author bluezealot
 */
@SuppressWarnings("rawtypes")
public class AS400Dialect extends AbstractHelperDialect {

	@Override
	public Object processPageParameter(MappedStatement ms, Map<String, Object> paramMap,
			Page page, BoundSql boundSql, CacheKey pageKey) {
		paramMap.put(PAGEPARAMETER_FIRST, page.getStartRow());
		paramMap.put(PAGEPARAMETER_SECOND, page.getPageSize());
		pageKey.update(page.getStartRow());
		pageKey.update(page.getPageSize());
		handleParameter(boundSql, ms, long.class, int.class);
		return paramMap;
	}

	@Override
	public String getPageSql(String sql, Page page, CacheKey pageKey) {
		return sql + " OFFSET ? ROWS FETCH FIRST ? ROWS ONLY";
	}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值