不同数据库的分页方法

这篇博客探讨了如何在MybatisPlus中处理不同的数据库分页需求。当默认的数据库类型不满足时,可以通过扩展`IDialect`类来自定义SQL拼接,例如对于POSTGRE_SQL的分页处理。通过DialectFactory获取方言实例,并展示了不同数据库的分页SQL示例。如果需要更多数据库支持,可以按类似方式扩展。
摘要由CSDN通过智能技术生成

还在造轮子吗,mybatis源码那十几个数据库不够用吗


import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.extension.plugins.pagination.DialectFactory;
import com.baomidou.mybatisplus.extension.plugins.pagination.DialectModel;
import com.baomidou.mybatisplus.extension.plugins.pagination.dialects.IDialect;

/**
 * @author lanyanhua
 * @date 2022/11/29 5:23 下午
 * @description
 */
public class MybatisPlusPageTest {

    public static void main(String[] args) {
        DbType dbType = DbType.POSTGRE_SQL;
        IDialect dialect = DialectFactory.getDialect(dbType);
        DialectModel model = dialect.buildPaginationSql("select * from table", 1, 10);
        System.out.println(model.getDialectSql());
        //DbType.MYSQL select * from table LIMIT ?,?
        //DbType.ORACLE  SELECT * FROM ( SELECT TMP.*, ROWNUM ROW_ID FROM ( select * from table ) TMP WHERE ROWNUM <=?) WHERE ROW_ID > ?
        //DbType.ORACLE_12C select * from table OFFSET ? ROWS FETCH NEXT ? ROWS ONLY
        //DbType.SQL_SERVER select * from table OFFSET ? ROWS FETCH NEXT ? ROWS ONLY
        //DbType.POSTGRE_SQL select * from table LIMIT ? OFFSET ?
    }
}

 万一真不够用怎么办呢

那就自己扩展一下 IDialect 类吧,写法其实就跟自己拼接sql一样。

扩展完后再加一下这个DialectFactory,dbType

DialectFactory.getDialect(dbType)

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值