mybatis-plus随机查询工具类

简介: mybatis-plus随机查询工具类

作为一个人,对父母要尊敬,对子女要慈爱,对穷亲戚要慷慨,对一切人要有礼貌。——(美国)罗素

都封装好了

/**
 * 随机取几条
 *
 * @param function 表名::列名
 * @return T
 * @author <achao1441470436@gmail.com>
 * @since 2021/5/17 0017 10:34
 */
@SuppressWarnings("unchecked")
public static <T, O> List<O> getAny(SFunction<O, T> function, Integer limit) {
    SerializedLambda lambda = Optional.ofNullable(function).map(LambdaUtils::resolve).orElseThrow(() -> ExceptionUtils.mpe("传入条件不能为空"));
    Class<O> entityClass = (Class<O>) lambda.getImplClass();
    TableInfo tableInfo = Optional.ofNullable(entityClass).map(TableInfoHelper::getTableInfo).orElseThrow(() -> ExceptionUtils.mpe("未找到该实体类对应BaseMapper,请注入对应mybatis-plus的BaseMapper"));
    String tableName = tableInfo.getTableName();
    String id = PropertyNamer.methodToProperty(lambda.getImplMethodName());
    List<HashMap<String, Object>> mapList = (List<HashMap<String, Object>>) USER_MAPPER.getAny(tableName, id, limit, entityClass);
    List<TableFieldInfo> fieldList = tableInfo.getFieldList();
    Reflector reflector = new Reflector(entityClass);
    Map<String, Invoker> columnSetterMap = fieldList.parallelStream().collect(Collectors.toMap(tbf -> Optional.ofNullable(tbf).map(TableFieldInfo::getField).map(field -> field.getAnnotation(TableField.class)).map(TableField::value).filter(StringUtils::isNotBlank).orElse(Objects.requireNonNull(tbf).getProperty()), f -> reflector.getSetInvoker(f.getProperty()), (v1, v2) -> v2));
    return mapList.stream().map(map -> {
        O bean = ClassUtils.newInstance(entityClass);
        map.forEach((key, value) -> Optional.ofNullable(key).map(columnSetterMap::get).ifPresent(i -> {
            try {
                i.invoke(bean, new Object[]{value});
            } catch (IllegalAccessException | InvocationTargetException e) {
                e.printStackTrace();
            }
        }));
        return bean;
    }).collect(Collectors.toList());
}
/**
 * 随机取一条
 *
 * @param function 表名::列名
 * @return O 随便取的
 * @author <achao1441470436@gmail.com>
 * @since 2021/5/17 0017 12:29
 */
public static <O> O getAnyOne(SFunction<O, ?> function) {
    return getAny(function, 1).parallelStream().findAny().orElse(null);
}

这里的USER_MAPPER我们可以使用任意一个mapper,我这里使用的是静态注入的方式

private static final UserMapper USER_MAPPER = SpringContextHolder.getBean(UserMapper.class);

然后是mapper里的方法

/**
 * 随机取一条
 *
 * @param tableName  表名
 * @param columnName 列名
 * @param limit      取几条
 * @return O
 * @author <achao1441470436@gmail.com>
 * @since 2021/5/17 0017 10:47
 */
<O> List<O> getAny(@Param("table_name") String tableName, @Param("id") String columnName, @Param("limit") Integer limit, Class<O> type);

以及对应的xml

<!--  随机取一条  -->
<select id="getAny" resultType="java.util.Map">
    SELECT *
    FROM ${table_name} AS t1 JOIN (SELECT ROUND(RAND() *((SELECT MAX(${id}) FROM ${table_name}) - (SELECT MIN(${id}) FROM ${table_name})) +(SELECT MIN(${id}) FROM ${table_name})) AS tmp_id) AS t2
    WHERE t1.${id} >= t2.tmp_id
    ORDER BY t1.${id} LIMIT #{limit};
</select>

实际使用场景、方式

相关文章
|
30天前
|
SQL Java 关系型数据库
Mybatis多表关联查询与动态SQL(下)
Mybatis多表关联查询与动态SQL
43 0
|
30天前
|
SQL Java 数据库连接
Mybatis多表关联查询与动态SQL(上)
Mybatis多表关联查询与动态SQL
23 0
|
30天前
|
SQL 缓存 Java
mybatis 一对多查询
mybatis 一对多查询
32 0
|
30天前
|
SQL
MyBatis-Plus-Join关联查询
MyBatis-Plus-Join关联查询
|
30天前
|
SQL XML Java
MyBatis-Plus多表关联查询
MyBatis-Plus多表关联查询
|
16天前
|
SQL Java 数据库连接
MyBatis 查询数据库
MyBatis 查询数据库
|
21天前
|
算法 BI 数据库
MyBatisPlus查询条件设置、映射匹配兼容性、id生成策略、多数据操作
MyBatisPlus查询条件设置、映射匹配兼容性、id生成策略、多数据操作
32 3
|
30天前
|
SQL XML API
Mybatis-Plus实现查询操作
Mybatis-Plus实现查询操作
34 0
Mybatis-Plus实现查询操作
|
30天前
|
Java 数据库连接 mybatis
MyBatis-Plus查询工具类
MyBatis-Plus是一个MyBatis的增强工具类库,提供了许多实用的查询工具类。
14 0
|
30天前
|
SQL Java 数据库连接
Javaweb之Mybatis的基础操作之查询操作的详细解析
Javaweb之Mybatis的基础操作之查询操作的详细解析
33 0