Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
io.mybatis.mapper.example.ExampleWrapper Maven / Gradle / Ivy
/*
* Copyright 2020-2022 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package io.mybatis.mapper.example;
import io.mybatis.common.util.Assert;
import io.mybatis.mapper.BaseMapper;
import io.mybatis.mapper.fn.Fn;
import org.apache.ibatis.exceptions.TooManyResultsException;
import org.apache.ibatis.session.RowBounds;
import java.io.Serializable;
import java.util.Arrays;
import java.util.List;
import java.util.Optional;
import java.util.function.Function;
import java.util.function.Supplier;
import java.util.stream.Collectors;
import java.util.stream.Stream;
/**
* 封装 Example 的查询条件,方便链式调用
*
* @param 实体类类型
* @param 主键类型
* @author liuzh
*/
public class ExampleWrapper {
private final BaseMapper baseMapper;
private final Example example;
private Example.Criteria current;
public ExampleWrapper(BaseMapper baseMapper, Example example) {
this.baseMapper = baseMapper;
this.example = example;
this.current = example.createCriteria();
}
/**
* or 一组条件
*
* @return 条件
*/
public ExampleWrapper or() {
this.current = this.example.or();
return this;
}
/**
* 获取查询条件
*/
public Example example() {
return example;
}
/**
* 清除条件,可重用
*/
public ExampleWrapper clear() {
this.example.clear();
this.current = example.createCriteria();
return this;
}
/**
* 指定查询列
*
* @param fns 方法引用
*/
@SafeVarargs
public final ExampleWrapper select(Fn... fns) {
this.example.selectColumns(fns);
return this;
}
/**
* 排除指定查询列
*
* @param fns 方法引用
*/
@SafeVarargs
public final ExampleWrapper exclude(Fn... fns) {
this.example.excludeColumns(fns);
return this;
}
/**
* 设置起始 SQL
*
* @param startSql 起始 SQL,添加到 SQL 前,注意防止 SQL 注入
*/
public ExampleWrapper startSql(String startSql) {
this.example.setStartSql(startSql);
return this;
}
/**
* 设置结尾 SQL
*
* @param endSql 结尾 SQL,添加到 SQL 最后,注意防止 SQL 注入
*/
public ExampleWrapper endSql(String endSql) {
this.example.setEndSql(endSql);
return this;
}
/**
* 通过方法引用方式设置排序字段
*
* @param fn 排序列的方法引用
* @param order 排序方式
* @return Example
*/
public ExampleWrapper orderBy(Fn fn, Example.Order order) {
this.example.orderBy(fn, order);
return this;
}
/**
* 支持使用字符串形式来设置 order by,用以支持一些特殊的排序方案
*
* @param orderByCondition 排序字符串(不会覆盖已有的排序内容)
* @return Example
*/
public ExampleWrapper orderBy(String orderByCondition) {
this.example.orderBy(orderByCondition);
return this;
}
/**
* 支持使用字符串形式来设置 order by,用以支持一些特殊的排序方案
*
* @param orderByCondition 排序字符串构造方法,比如通过数组集合循环拼接等
* @return Example
*/
public ExampleWrapper orderBy(Supplier orderByCondition) {
this.example.orderBy(orderByCondition);
return this;
}
/**
* 支持使用字符串形式来设置 order by,用以支持一些特殊的排序方案
*
* @param useOrderBy 条件表达式,true使用,false不使用 字符串排序
* @param orderByCondition 排序字符串构造方法,比如通过数组集合循环拼接等
* @return Example
*/
public ExampleWrapper orderBy(boolean useOrderBy, Supplier orderByCondition) {
return useOrderBy ? this.orderBy(orderByCondition) : this;
}
/**
* 通过方法引用方式设置排序字段,升序排序
*
* @param fns 排序列的方法引用
* @return Example
*/
@SafeVarargs
public final ExampleWrapper orderByAsc(Fn... fns) {
this.example.orderByAsc(fns);
return this;
}
/**
* 通过方法引用方式设置排序字段,降序排序
*
* @param fns 排序列的方法引用
* @return Example
*/
@SafeVarargs
public final ExampleWrapper orderByDesc(Fn... fns) {
this.example.orderByDesc(fns);
return this;
}
/**
* 设置 distince
*/
public ExampleWrapper distinct() {
this.example.setDistinct(true);
return this;
}
/**
* 设置更新字段和值
*
* @param useSet 表达式条件, true 使用,false 不使用
* @param setSql "column = value"
*/
public ExampleWrapper set(boolean useSet, String setSql) {
return useSet ? set(setSql) : this;
}
/**
* 设置更新字段和值
*
* @param setSql "column = value"
*/
public ExampleWrapper set(String setSql) {
this.example.set(setSql);
return this;
}
/**
* 设置更新字段和值
*
* @param useSet 表达式条件, true 使用,false 不使用
* @param fn 字段
* @param value 值
*/
public ExampleWrapper set(boolean useSet, Fn fn, Object value) {
return useSet ? set(fn, value) : this;
}
/**
* 设置更新字段和值
*
* @param useSet 表达式条件, true 使用,false 不使用
* @param fn 字段
* @param supplier 值构造函数
*/
public ExampleWrapper set(boolean useSet, Fn fn, Supplier supplier) {
return useSet ? set(fn, supplier.get()) : this;
}
/**
* 设置更新字段和值
*
* @param fn 字段
* @param value 值
*/
public ExampleWrapper set(Fn fn, Object value) {
this.example.set(fn, value);
return this;
}
/**
* 指定字段为 null
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
*/
public ExampleWrapper isNull(boolean useCondition, Fn fn) {
return useCondition ? isNull(fn) : this;
}
/**
* 指定字段为 null
*
* @param fn 字段对应的 get 方法引用
*/
public ExampleWrapper isNull(Fn fn) {
this.current.addCriterion(fn.toColumn() + " IS NULL");
return this;
}
/**
* 指定字段不为 null
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
*/
public ExampleWrapper isNotNull(boolean useCondition, Fn fn) {
return useCondition ? isNotNull(fn) : this;
}
/**
* 指定字段不为 null
*
* @param fn 字段对应的 get 方法引用
*/
public ExampleWrapper isNotNull(Fn fn) {
this.current.addCriterion(fn.toColumn() + " IS NOT NULL");
return this;
}
/**
* 字段 = 值
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param value 值
*/
public ExampleWrapper eq(boolean useCondition, Fn fn, Object value) {
return useCondition ? eq(fn, value) : this;
}
/**
* 字段 = 值
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param supplier 值构造函数
*/
public ExampleWrapper eq(boolean useCondition, Fn fn, Supplier supplier) {
return useCondition ? eq(fn, supplier.get()) : this;
}
/**
* 字段 = 值
*
* @param fn 字段对应的 get 方法引用
* @param value 值
*/
public ExampleWrapper eq(Fn fn, Object value) {
this.current.addCriterion(fn.toColumn() + " =", value);
return this;
}
/**
* 字段 != 值
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param supplier 值构造函数
*/
public ExampleWrapper ne(boolean useCondition, Fn fn, Supplier supplier) {
return useCondition ? ne(fn, supplier.get()) : this;
}
/**
* 字段 != 值
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param value 值
*/
public ExampleWrapper ne(boolean useCondition, Fn fn, Object value) {
return useCondition ? ne(fn, value) : this;
}
/**
* 字段 != 值
*
* @param fn 字段对应的 get 方法引用
* @param value 值
*/
public ExampleWrapper ne(Fn fn, Object value) {
this.current.addCriterion(fn.toColumn() + " <>", value);
return this;
}
/**
* 字段 > 值
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param supplier 值构造函数
*/
public ExampleWrapper gt(boolean useCondition, Fn fn, Supplier supplier) {
return useCondition ? gt(fn, supplier.get()) : this;
}
/**
* 字段 > 值
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param value 值
*/
public ExampleWrapper gt(boolean useCondition, Fn fn, Object value) {
return useCondition ? gt(fn, value) : this;
}
/**
* 字段 > 值
*
* @param fn 字段对应的 get 方法引用
* @param value 值
*/
public ExampleWrapper gt(Fn fn, Object value) {
this.current.addCriterion(fn.toColumn() + " >", value);
return this;
}
/**
* 字段 >= 值
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param supplier 值构造函数
*/
public ExampleWrapper ge(boolean useCondition, Fn fn, Supplier supplier) {
return useCondition ? ge(fn, supplier.get()) : this;
}
/**
* 字段 >= 值
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param value 值
*/
public ExampleWrapper ge(boolean useCondition, Fn fn, Object value) {
return useCondition ? ge(fn, value) : this;
}
/**
* 字段 >= 值
*
* @param fn 字段对应的 get 方法引用
* @param value 值
*/
public ExampleWrapper ge(Fn fn, Object value) {
this.current.addCriterion(fn.toColumn() + " >=", value);
return this;
}
/**
* 字段 < 值
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
*/
public ExampleWrapper lt(boolean useCondition, Fn fn, Supplier supplier) {
return useCondition ? lt(fn, supplier.get()) : this;
}
/**
* 字段 < 值
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param value 值
*/
public ExampleWrapper lt(boolean useCondition, Fn fn, Object value) {
return useCondition ? lt(fn, value) : this;
}
/**
* 字段 < 值
*
* @param fn 字段对应的 get 方法引用
* @param value 值
*/
public ExampleWrapper lt(Fn fn, Object value) {
this.current.addCriterion(fn.toColumn() + " <", value);
return this;
}
/**
* 字段 <= 值
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param value 值
*/
public ExampleWrapper le(boolean useCondition, Fn fn, Object value) {
return useCondition ? le(fn, value) : this;
}
/**
* 字段 <= 值
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param supplier 值构造函数
*/
public ExampleWrapper le(boolean useCondition, Fn fn, Supplier supplier) {
return useCondition ? le(fn, supplier.get()) : this;
}
/**
* 字段 <= 值
*
* @param fn 字段对应的 get 方法引用
* @param value 值
*/
public ExampleWrapper le(Fn fn, Object value) {
this.current.addCriterion(fn.toColumn() + " <=", value);
return this;
}
/**
* 字段 in (值集合)
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param values 值集合
*/
@SuppressWarnings("rawtypes")
public ExampleWrapper in(boolean useCondition, Fn fn, Iterable values) {
return useCondition ? in(fn, values) : this;
}
/**
* 字段 in (值集合)
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param supplier 值集合构造函数
*/
@SuppressWarnings("rawtypes")
public ExampleWrapper in(boolean useCondition, Fn fn, Supplier supplier) {
return useCondition ? in(fn, supplier.get()) : this;
}
/**
* 字段 in (值集合)
*
* @param fn 字段对应的 get 方法引用
* @param values 值集合
*/
@SuppressWarnings("rawtypes")
public ExampleWrapper in(Fn fn, Iterable values) {
this.current.addCriterion(fn.toColumn() + " IN", values);
return this;
}
/**
* 字段 not in (值集合)
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param values 值集合
*/
@SuppressWarnings("rawtypes")
public ExampleWrapper notIn(boolean useCondition, Fn fn, Iterable values) {
return useCondition ? notIn(fn, values) : this;
}
/**
* 字段 not in (值集合)
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param supplier 值集合构造函数
*/
@SuppressWarnings("rawtypes")
public ExampleWrapper notIn(boolean useCondition, Fn fn, Supplier supplier) {
return useCondition ? notIn(fn, supplier.get()) : this;
}
/**
* 字段 not in (值集合)
*
* @param fn 字段对应的 get 方法引用
* @param values 值集合
*/
@SuppressWarnings("rawtypes")
public ExampleWrapper notIn(Fn fn, Iterable values) {
this.current.addCriterion(fn.toColumn() + " NOT IN", values);
return this;
}
/**
* 字段 between value1 and value 2
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param value1 值1
* @param value2 值2
*/
public ExampleWrapper between(boolean useCondition, Fn fn, Object value1, Object value2) {
return useCondition ? between(fn, value1, value2) : this;
}
/**
* 字段 between value1 and value 2
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param supplier1 值1构造函数
* @param supplier2 值2构造函数
*/
public ExampleWrapper between(boolean useCondition, Fn fn, Supplier supplier1, Supplier supplier2) {
return useCondition ? between(fn, supplier1.get(), supplier2.get()) : this;
}
/**
* 字段 between value1 and value 2
*
* @param fn 字段对应的 get 方法引用
* @param value1 值1
* @param value2 值2
*/
public ExampleWrapper between(Fn fn, Object value1, Object value2) {
this.current.addCriterion(fn.toColumn() + " BETWEEN", value1, value2);
return this;
}
/**
* 字段 not between value1 and value 2
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param value1 值1
* @param value2 值2
*/
public ExampleWrapper notBetween(boolean useCondition, Fn fn, Object value1, Object value2) {
return useCondition ? notBetween(fn, value1, value2) : this;
}
/**
* 字段 not between value1 and value 2
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param supplier1 值1构造函数
* @param supplier2 值2构造函数
*/
public ExampleWrapper notBetween(boolean useCondition, Fn fn, Supplier supplier1, Supplier supplier2) {
return useCondition ? notBetween(fn, supplier1.get(), supplier2.get()) : this;
}
/**
* 字段 not between value1 and value 2
*
* @param fn 字段对应的 get 方法引用
* @param value1 值1
* @param value2 值2
*/
public ExampleWrapper notBetween(Fn fn, Object value1, Object value2) {
this.current.addCriterion(fn.toColumn() + " NOT BETWEEN", value1, value2);
return this;
}
/**
* 字段 like %值%
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param value 值,两侧自动添加 %
*/
public ExampleWrapper contains(boolean useCondition, Fn fn, String value) {
return useCondition ? contains(fn, value) : this;
}
/**
* 字段 like %值%
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param supplier 值构造函数,两侧自动添加 %
*/
public ExampleWrapper contains(boolean useCondition, Fn fn, Supplier supplier) {
return useCondition ? contains(fn, supplier.get()) : this;
}
/**
* 字段 like %值%
*
* @param fn 字段对应的 get 方法引用
* @param value 值,两侧自动添加 %
*/
public ExampleWrapper contains(Fn fn, String value) {
this.current.addCriterion(fn.toColumn() + " LIKE", "%" + value + "%");
return this;
}
/**
* 字段 like 值%,匹配 value 为前缀的值
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param value 值,右侧自动添加 %
*/
public ExampleWrapper startsWith(boolean useCondition, Fn fn, String value) {
return useCondition ? startsWith(fn, value) : this;
}
/**
* 字段 like 值%,匹配 value 为前缀的值
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param supplier 值构造函数,右侧自动添加 %
*/
public ExampleWrapper startsWith(boolean useCondition, Fn fn, Supplier supplier) {
return useCondition ? startsWith(fn, supplier.get()) : this;
}
/**
* 字段 like 值%,匹配 value 为前缀的值
*
* @param fn 字段对应的 get 方法引用
* @param value 值,右侧自动添加 %
*/
public ExampleWrapper startsWith(Fn fn, String value) {
this.current.addCriterion(fn.toColumn() + " LIKE", value + "%");
return this;
}
/**
* 字段 like %值,匹配 value 为后缀的值
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param value 值,左侧自动添加 %
*/
public ExampleWrapper endsWith(boolean useCondition, Fn fn, String value) {
return useCondition ? endsWith(fn, value) : this;
}
/**
* 字段 like %值,匹配 value 为后缀的值
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param supplier 值构造函数,左侧自动添加 %
*/
public ExampleWrapper endsWith(boolean useCondition, Fn fn, Supplier supplier) {
return useCondition ? endsWith(fn, supplier.get()) : this;
}
/**
* 字段 like %值,匹配 value 为后缀的值
*
* @param fn 字段对应的 get 方法引用
* @param value 值,左侧自动添加 %
*/
public ExampleWrapper endsWith(Fn fn, String value) {
this.current.addCriterion(fn.toColumn() + " LIKE", "%" + value);
return this;
}
/**
* 字段 like 值
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param value 值,需要指定 '%'(多个), '_'(单个) 模糊匹配
*/
public ExampleWrapper like(boolean useCondition, Fn fn, String value) {
return useCondition ? like(fn, value) : this;
}
/**
* 字段 like 值
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param supplier 值构造函数,需要指定 '%'(多个), '_'(单个) 模糊匹配
*/
public ExampleWrapper like(boolean useCondition, Fn fn, Supplier supplier) {
return useCondition ? like(fn, supplier.get()) : this;
}
/**
* 字段 like 值
*
* @param fn 字段对应的 get 方法引用
* @param value 值,需要指定 '%'(多个), '_'(单个) 模糊匹配
*/
public ExampleWrapper like(Fn fn, String value) {
this.current.addCriterion(fn.toColumn() + " LIKE", value);
return this;
}
/**
* 字段 not like 值
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param value 值,需要指定 % 模糊匹配
*/
public ExampleWrapper notLike(boolean useCondition, Fn fn, String value) {
return useCondition ? notLike(fn, value) : this;
}
/**
* 字段 not like 值
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param fn 字段对应的 get 方法引用
* @param supplier 值构造函数,需要指定 % 模糊匹配
*/
public ExampleWrapper notLike(boolean useCondition, Fn fn, Supplier supplier) {
return useCondition ? notLike(fn, supplier.get()) : this;
}
/**
* 字段 not like 值
*
* @param fn 字段对应的 get 方法引用
* @param value 值,需要指定 % 模糊匹配
*/
public ExampleWrapper notLike(Fn fn, String value) {
this.current.addCriterion(fn.toColumn() + " NOT LIKE", value);
return this;
}
/**
* 添加任意条件,条件一定是后端使用的,需要自己防止 SQL 注入
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param condition 任意条件,例如 "length(countryname)<5"
*/
public ExampleWrapper anyCondition(boolean useCondition, String condition) {
return useCondition ? anyCondition(condition) : this;
}
/**
* 添加任意条件,条件一定是后端使用的,需要自己防止 SQL 注入
*
* @param condition 任意条件,例如 "length(countryname)<5"
*/
public ExampleWrapper anyCondition(String condition) {
this.current.andCondition(condition);
return this;
}
/**
* 手写左边条件,右边用value值
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param condition 例如 "length(countryname)="
* @param value 例如 5
*/
public ExampleWrapper anyCondition(boolean useCondition, String condition, Object value) {
return useCondition ? anyCondition(condition, value) : this;
}
/**
* 手写左边条件,右边用value值
*
* @param useCondition 表达式条件, true 使用,false 不使用
* @param condition 例如 "length(countryname)="
* @param supplier 任意条件值的构造函数
*/
public ExampleWrapper anyCondition(boolean useCondition, String condition, Supplier supplier) {
return useCondition ? anyCondition(condition, supplier.get()) : this;
}
/**
* 手写左边条件,右边用value值
*
* @param condition 例如 "length(countryname)="
* @param value 例如 5
*/
public ExampleWrapper anyCondition(String condition, Object value) {
this.current.andCondition(condition, value);
return this;
}
/**
* 嵌套 or 查询,数组多个条件直接使用 or,单个条件中为 and
*
* @param orParts 条件块
*/
@SafeVarargs
public final ExampleWrapper or(Function, Example.OrCriteria>... orParts) {
if (orParts != null && orParts.length > 0) {
this.current.andOr(Arrays.stream(orParts).map(orPart -> orPart.apply(example.orPart())).collect(Collectors.toList()));
}
return this;
}
/**
* 根据当前条件删除
*/
public int delete() {
return baseMapper.deleteByExample(example);
}
/**
* 将符合当前查询条件的数据更新为 {@link #set(String)} 和 {@link #set(Fn, Object)} 设置的值
*/
public int update() {
Assert.notEmpty(example.getSetValues(), "必须通过 set 方法设置更新的列和值");
return baseMapper.updateByExampleSetValues(example);
}
/**
* 将符合当前查询条件的数据更新为提供的值, {@link #set(String)} 和 {@link #set(Fn, Object)} 设置的值无效
*
* @param t 要更新的值
*/
public int update(T t) {
return baseMapper.updateByExample(t, example);
}
/**
* 将符合当前查询条件的数据更新为提供的值,不更新 null 的值
*
* @param t 要更新的值
*/
public int updateSelective(T t) {
return baseMapper.updateByExampleSelective(t, example);
}
/**
* 根据当前查询条件查询
*/
public List list() {
return baseMapper.selectByExample(example);
}
/**
* 根据当前查询条件查询,返回 Stream
*/
public Stream stream() {
return list().stream();
}
/**
* 根据当前查询条件查询出一个结果,当存在多个符合条件的结果时会抛出异常 {@link TooManyResultsException}
*/
public Optional one() {
return baseMapper.selectOneByExample(example);
}
/**
* 根据当前查询条件查询出第一个结果,通过 {@link RowBounds} 实现
*/
public Optional first() {
return baseMapper.selectByExample(example, new RowBounds(0, 1)).stream().findFirst();
}
/**
* 根据当前查询条件查询出前 n 个结果,通过 {@link RowBounds} 实现
*
* @param n 结果数
*/
public List top(int n) {
return baseMapper.selectByExample(example, new RowBounds(0, n));
}
/**
* 查询符合当前条件的结果数
*/
public long count() {
return baseMapper.countByExample(example);
}
}