最近项目数据库用到mongodb,采用jpa查询时碰到不少问题,查询各资源均未找到好的解决方案,如无法搜索数字等,以下为本人实现方式,写出来给有需要的人!
以下为部分代码,基础部分大家应该都很清楚了
1、对查询字符串转义,以处理输入为regex的特定字符(同时允许输入以数字开头的模糊查询):
//regex对输入特殊字符转义
String escapeExprSpecialWord(String keyword) {
if (StringUtils.isNotBlank(keyword)) {
String[] fbsArr = { "\\", "$", "(", ")", "*", "+", ".", "[", "]", "?", "^", "{", "}", "|" };
for (String key : fbsArr) {
if (keyword.contains(key)) {
keyword = keyword.replace(key, "\\" + key);
}
}
}
return keyword;
}
//以下部分为