前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >mybatis-plus随机查询工具类(二)

mybatis-plus随机查询工具类(二)

作者头像
阿超
发布2022-08-17 19:41:52
2.5K0
发布2022-08-17 19:41:52
举报
文章被收录于专栏:快乐阿超

当真理还正在穿鞋的时候,谎言就能走遍半个世界。——马克吐温

之前写过一个,最近感觉不好用

然后写了一个更优雅的

代码语言:javascript
复制
/**
 * 随机查询
 *
 * @param mapper 持久层DAO
 * @param limit  随机条数
 * @return java.util.List<T>
 * @author <achao1441470436@gmail.com>
 * @since 2021/8/10 15:30
 */
public static <T> List<T> getAny(BaseMapper<T> mapper, T condition, Integer limit) {
    LambdaQueryWrapper<T> wrapper = Wrappers.lambdaQuery(condition);
    Integer total = mapper.selectCount(wrapper);
    if (limit == null || limit <= 0 || total == 0) {
        return Collections.emptyList();
    }
    List<T> list = Optional.of(limit).filter(l -> l > total).map(l -> mapper.selectList(wrapper)).orElseGet(() -> mapper.selectList(wrapper.last("LIMIT " + new SecureRandom().nextInt(total - (limit - 1)) + "," + limit)));
    Collections.shuffle(list);
    return list;
}

使用方式同样很简单

两个例子:

调用方传入对应的DAO和条件参数以及limit随机获取的条数即可

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021-08-10,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档