// 如果有标识符,添加模糊匹配规则
if (identifier != null && !identifier.isEmpty()) {
String lowerCaseIdentifier = identifier.toLowerCase(); // 转换为小写以进行不区分大小写的比较
eventDataDTOs = eventDataDTOs.stream()
.filter(eventDataDTO -> eventDataDTO.getIdentifier().toLowerCase().contains(lowerCaseIdentifier))
.collect(Collectors.toList());
}
// 如果有标识符,添加正则匹配规则
if (identifier != null && !identifier.isEmpty()) {
eventDataDTOs = eventDataDTOs.stream()
.filter(eventDataDTO -> eventDataDTO.getIdentifier().matches("(?i)" + identifier))
.collect(Collectors.toList());
}
上面两种写法实现的模糊查询时有区别的,通常第一种适用范围更宽泛的模糊匹配!
区别如下:
如果你小子想要实现一个更宽泛的模糊匹配,可以使用 contains
方法而不是 matches
。
Beacause:这里使用了 toLowerCase()
方法将标识符和目标进行小写转换,以确保不区分大小写。然后,使用 contains
方法来检查标识符是否包含所需的子字符串。这样,无论输入的大小写如何,都将进行模糊匹配。这样的实现会更符合您的期望。