generator生成分页mysql_mybatis-generator 插件扩展,生成支持多种数据库的分页功能...

背景: 在使用mybatis的过程中,考虑到整合的框架在后期使用的过程中,有可能是需要兼容到多种数据库的,在这种前提条件下,完成通用CRUD功能的编写,本文前期先考虑到不同数据库针对分页功能的统一操作;例如mysql数据库的分页是limit关键字的使用, oracle数据库的分页是rownum关键字的使用;

demo git地址部分: 外链网址已屏蔽

此例中主要使用的属性为  databaseIdProvider, 通过这个属性的使用,来生成支持多种数据库的sql分页语句:

MutiDatasourcePaginationPlugin  类文件为扩展的mybatis-generator 插件,用来在生成代码文件的过程中,完成不同数据库支持下的分页逻辑代码部分;

此例中只需要关心生成的 MutiDatabaseMapper.xml:

parameterType="com.alexgaoyh.MutiModule.persist.mutiDatabase.MutiDatabaseExample">

select

distinct

from mutidatabase mutiDatabase

order by ${orderByClause}

select * from ( select row_.*, rownum rownum_ from (

#{page.begin} and rownum_ <= #{page.end} ]]>

limit #{page.begin} , #{page.length}

这样,通过databaseIdProvider  的不同,就完成不同sql语句的引入操作;

部分链接:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值