PageHelper这种情况下有坑

因为最近工作实在太忙,肝了一段时间后,终于有空来写点文章了。闲话少说,进入本期内容的正题。

省流版本:PagerHelper在与PostgreSQL搭配使用时,会有坑!

你如果想知道具体是什么样的一个坑,往下看,我来给大伙儿展开说说。

背景

最近在做一个项目,常规的SpringBoot+Mybatis架构,数据库使用的是PostgreSQL,并且有一些场景需要使用到分页查询,很自然的就使用了PageHelper这个分页工具,如果你是初学者或者还没有使用过PageHelper,可以了解一下。PageHelper

到这里一切都很顺利,但是聪明如你一定猜到了,要有什么事情发生。

我需要完成一个数据权限的功能,根据每个用户的数据权限不同,控制每个用户只能查询到自己有权限的用户。

比如用户A只能访问他所在组织的数据,用户B是一个高级用户,能查询到多个组织的数据,用户C是超级管理员,能查询到所有数据等。

实现这个功能我采用的方式是在进行查询时,按照用户的权限不同,增加对应的查询条件。

比如业务方法中SQL是这样的:

select * from t_data where data_id = 1 limit 10 offset 0
复制代码

我需要修改成:

select * from t_data where data_id = 1 and data_part in (1,2,3) limit 10 offset 0
复制代码

这里需要强调一点,就是我不仅要对t_data这一张表增加条件,还要对其他很多张表加条件,并且可能每张表加的条件还不一样。

我采用了MyBatis的拦截器功能,在拦截器中统一对SQL进行处理,添加数据权限条件。

原以为一切会和我的预期一样,没想到中途踩了一个坑,让我折腾了半晚上。

以上是踩坑的背景,接下来看一下代码。

代码实现

我在拦截器中是这样做的。

MyBatis拦截器实现


/**
 * 数据权限拦截器
 * 拦截所有MyBatis的查询方法
 * @author 小黑说
 * @version 1.0
 */
@Intercepts({
    @Signature(type = Executor.class, method = "query",args = {MappedStatement.class, Object.class, RowBounds.class, ResultHandler.class}),
    @Signature(type = Executor.class, method = "query", args = {MappedStatement.class, Object.class, RowBounds.class, ResultHandler.class, CacheKey.class, BoundSql.class})})
public class DataPermissionInterceptor implements Interceptor {

    private static final Logger log = LoggerFactory.getLogger(DataPermissionInterceptor.class);

    @Override
    public Object intercept(Invocation invocation) throws Throwable {
        // 这是一个提前处理好的当前用户数据权限的集合,存放在ThreadLocal中。
        List<Condition> conditions = DataConditionHelper.getConditions();

        // 如果conditions为空代表该用户没有数据权限的限制,可以查询所有数据。
        if (CollectionUtils.isEmpty(conditions)) {
            return invocation.proceed();
        }

        Object[] args = invocation.getArgs();
        MappedStatement ms = (MappedStatement) args[0];
        Object parameter = args[1];
        RowBounds rowBounds = (RowBounds) args[2];
        ResultHandler resultHandler = 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PageHelper 是一个用于分页查询的开源工具,它可以帮助我们方便地处理分页查询的逻辑。然而,在使用 PageHelper 的过程中,确实存在一些常见的需要注意。 1. 方法调用位置:在使用 PageHelper.startPage 方法时,需要确保该方法调用在实际的查询方法之前。这是因为 PageHelper 使用 ThreadLocal 来保存分页参数,如果调用顺序不正确,可能会导致分页参数无法正确传递,从而出现分页不生效的问题。 2. 分页参数设置:PageHelper.startPage 方法接受两个参数,分别是页码和每页显示的数量。需要注意的是,页码从 1 开始计数,而不是从 0 开始。另外,如果不设置每页显示数量,默认会查询出所有符合条件的数据,这可能会导致性能问题。 3. 复杂查询条件:在使用 PageHelper 进行复杂查询时,需要注意一些特殊情况。例如,如果查询条件中包含了子查询或者多表关联查询,可能会导致分页结果错误。这时可以考虑使用 PageInterceptor 来处理复杂查询。 4. 结果集合处理:PageHelper 在处理分页查询时,会将查询结果封装成一个 Page 对象,其中包含了分页信息和查询结果列表。如果需要对结果集进行进一步处理,需要注意使用 Page 对象提供的方法。 总之,在使用 PageHelper 进行分页查询时,需要注意方法调用位置、分页参数设置、复杂查询条件和结果集合处理等方面的问题,以避免出现常见的

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值