【升级】彻底优化登录逻辑、大数据量下的机构以及in拆分

This commit is contained in:
俞宝山
2026-02-12 21:11:53 +08:00
parent 6e1a071a73
commit 8dcf6075ff
26 changed files with 1090 additions and 284 deletions

View File

@@ -0,0 +1,65 @@
/*
* Copyright [2022] [https://www.xiaonuo.vip]
*
* Snowy采用APACHE LICENSE 2.0开源协议,您在使用过程中,需要注意以下几点:
*
* 1.请不要删除和修改根目录下的LICENSE文件。
* 2.请不要删除和修改Snowy源码头部的版权声明。
* 3.本项目代码可免费商业使用,商业使用请保留源码和相关描述文件的项目出处,作者声明等。
* 4.分发源码时候,请注明软件出处 https://www.xiaonuo.vip
* 5.不可二次分发开源参与同类竞品如有想法可联系团队xiaonuobase@qq.com商议合作。
* 6.若您的项目无法满足以上几点需要更多功能代码获取Snowy商业授权许可请在官网购买授权地址为 https://www.xiaonuo.vip
*/
package vip.xiaonuo.common.util;
import cn.hutool.core.collection.CollectionUtil;
import cn.hutool.core.util.ObjectUtil;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.support.SFunction;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
/**
* SQL工具类处理数据库兼容性问题
*
* @author yubaoshan
* @date 2026/2/12 18:43
**/
public class CommonSqlUtil {
/** Oracle IN子句最大元素数量限制 */
private static final int IN_CLAUSE_LIMIT = 999;
/**
* 安全的IN查询自动处理Oracle IN子句1000限制
* 当集合大小超过999时自动拆分为多个IN子句用OR连接
* (column IN (...999个) OR column IN (...999个) OR ...)
*
* @param wrapper MyBatis-Plus LambdaQueryWrapper
* @param column 查询列
* @param values IN子句的值集合
* @param <T> 实体类型
*/
public static <T> void safeIn(LambdaQueryWrapper<T> wrapper, SFunction<T, ?> column, Collection<?> values) {
if (ObjectUtil.isEmpty(values)) {
return;
}
if (values.size() <= IN_CLAUSE_LIMIT) {
wrapper.in(column, values);
return;
}
List<?> valueList = values instanceof List ? (List<?>) values : new ArrayList<>(values);
List<? extends List<?>> partitions = CollectionUtil.split(valueList, IN_CLAUSE_LIMIT);
wrapper.and(w -> {
for (int i = 0; i < partitions.size(); i++) {
if (i == 0) {
w.in(column, partitions.get(i));
} else {
w.or().in(column, partitions.get(i));
}
}
});
}
}