Android + ObjectBox 搜索查询问题
Android + ObjectBox Search Query Issue
我被 ObjectBox Like 查询困住了。我在搜索东西时做了如下操作。
QueryBuilder<MItemDetail> builder = mItemDetailListBox.query();
builder.contains(MItemDetail_.productName, search);
itemList = builder.build().find();
例如,我的数据是:
- 扑热息痛
- 扑热息痛测试
- paracetamol_new
问题:
如您所知,包含 的工作原理与 returns 包含给定搜索字符串的项目列表一样简单。
我想要什么:
如果我搜索 para new,我想要结果 paracetamol_new
如果我搜索 para p,我想要结果 paracetamol potest
如果我搜索 para e e,我想要结果 paracetamol potest 和 paracetamol_new
ObjectBox 中是否有任何功能或实用程序可以帮助我实现此目的?
如果您有任何问题,请告诉我。
已编辑:
评论中给出的链接,我的问题不一样。我知道所有方法 contains()
、startsWith
和 endsWith
,但我的问题并没有得到解决。
参考这个我做了一些修改,得到了我想要的完美解决方案。
QueryBuilder<MItemDetail> builder = mItemDetailListBox.query();
// builder.contains(MItemDetail_.productName, search);
builder.filter(new QueryFilter<MItemDetail>() {
@Override
public boolean keep(@NonNull MItemDetail entity) {
return like(entity.getProductName(), "%"+ search + "%");
}
}).order(MItemDetail_.productName);
businessModels = builder.build().find();
在下面的方法中,我又添加了一条replace语句.replace(" ",".*?")
private static boolean like(final String str, final String expr) {
String safeString = (str == null) ? "" : str;
String regex = quoteMeta(expr);
regex = regex.replace("_", ".").replace(" ",".*?").replace("%", ".*?");
Pattern p = Pattern.compile(regex,
Pattern.CASE_INSENSITIVE | Pattern.DOTALL);
return p.matcher(safeString).matches();
}
private static String quoteMeta(String s) {
if (s == null) {
throw new IllegalArgumentException("String cannot be null");
}
int len = s.length();
if (len == 0) {
return "";
}
StringBuilder sb = new StringBuilder(len * 2);
for (int i = 0; i < len; i++) {
char c = s.charAt(i);
if ("[](){}.*+?$^|#\".indexOf(c) != -1) {
sb.append("\");
}
sb.append(c);
}
return sb.toString();
}
谢谢。
我被 ObjectBox Like 查询困住了。我在搜索东西时做了如下操作。
QueryBuilder<MItemDetail> builder = mItemDetailListBox.query();
builder.contains(MItemDetail_.productName, search);
itemList = builder.build().find();
例如,我的数据是:
- 扑热息痛
- 扑热息痛测试
- paracetamol_new
问题:
如您所知,包含 的工作原理与 returns 包含给定搜索字符串的项目列表一样简单。
我想要什么:
如果我搜索 para new,我想要结果 paracetamol_new
如果我搜索 para p,我想要结果 paracetamol potest
如果我搜索 para e e,我想要结果 paracetamol potest 和 paracetamol_new
ObjectBox 中是否有任何功能或实用程序可以帮助我实现此目的?
如果您有任何问题,请告诉我。
已编辑:
评论中给出的链接,我的问题不一样。我知道所有方法 contains()
、startsWith
和 endsWith
,但我的问题并没有得到解决。
参考这个
QueryBuilder<MItemDetail> builder = mItemDetailListBox.query();
// builder.contains(MItemDetail_.productName, search);
builder.filter(new QueryFilter<MItemDetail>() {
@Override
public boolean keep(@NonNull MItemDetail entity) {
return like(entity.getProductName(), "%"+ search + "%");
}
}).order(MItemDetail_.productName);
businessModels = builder.build().find();
在下面的方法中,我又添加了一条replace语句.replace(" ",".*?")
private static boolean like(final String str, final String expr) {
String safeString = (str == null) ? "" : str;
String regex = quoteMeta(expr);
regex = regex.replace("_", ".").replace(" ",".*?").replace("%", ".*?");
Pattern p = Pattern.compile(regex,
Pattern.CASE_INSENSITIVE | Pattern.DOTALL);
return p.matcher(safeString).matches();
}
private static String quoteMeta(String s) {
if (s == null) {
throw new IllegalArgumentException("String cannot be null");
}
int len = s.length();
if (len == 0) {
return "";
}
StringBuilder sb = new StringBuilder(len * 2);
for (int i = 0; i < len; i++) {
char c = s.charAt(i);
if ("[](){}.*+?$^|#\".indexOf(c) != -1) {
sb.append("\");
}
sb.append(c);
}
return sb.toString();
}
谢谢。