feat: 新增多个字段模查询,兼容旧逻辑
This commit is contained in:
@@ -140,19 +140,32 @@ public class CrudOption<T> {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
Object keyWord = requestParams.get("keyWord");
|
if (ObjectUtil.isNotEmpty(this.keyWordLikeFields)) {
|
||||||
if (ObjectUtil.isNotEmpty(this.keyWordLikeFields) && ObjectUtil.isNotEmpty(keyWord)) {
|
Object keyWord = requestParams.get("keyWord");
|
||||||
// 初始化一个空的 QueryCondition
|
if (ObjectUtil.isEmpty(keyWord)) {
|
||||||
QueryCondition orCondition = null;
|
// // keyWord值为空,遍历keyWordLikeFields字段,根据queryColumn字段名构建查询条件
|
||||||
for (QueryColumn queryColumn : keyWordLikeFields) {
|
for (QueryColumn queryColumn : keyWordLikeFields) {
|
||||||
QueryCondition condition = queryColumn.like(keyWord);
|
String fieldName = queryColumn.getName();
|
||||||
if (orCondition == null) {
|
String paramName = StrUtil.toCamelCase(fieldName);
|
||||||
orCondition = condition;
|
String paramValue = requestParams.getStr(paramName);
|
||||||
} else {
|
if (ObjectUtil.isNotEmpty(paramValue)) {
|
||||||
orCondition = orCondition.or(condition);
|
queryWrapper.and(queryColumn.like(paramValue));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
// keyWord值非空,使用keyWord构建
|
||||||
|
// 初始化一个空的 QueryCondition
|
||||||
|
QueryCondition orCondition = null;
|
||||||
|
for (QueryColumn queryColumn : keyWordLikeFields) {
|
||||||
|
QueryCondition condition = queryColumn.like(keyWord);
|
||||||
|
if (orCondition == null) {
|
||||||
|
orCondition = condition;
|
||||||
|
} else {
|
||||||
|
orCondition = orCondition.or(condition);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
queryWrapper.and(orCondition);
|
||||||
}
|
}
|
||||||
queryWrapper.and(orCondition);
|
|
||||||
}
|
}
|
||||||
if (ObjectUtil.isNotEmpty(select)) {
|
if (ObjectUtil.isNotEmpty(select)) {
|
||||||
queryWrapper.select(select);
|
queryWrapper.select(select);
|
||||||
|
|||||||
Reference in New Issue
Block a user