[英]How to make a more flexible search query using parse.com
我有一个充满用户和他们的信息的数据库,我使用parse.com来搜索他们。
现在,为了使搜索更好一点,并使其灵活使用大写字母,重音符号等,我有一个名为search_helper的列,该列在用户注册或更新其信息时被填充,如下所示:
String fullNameNormalized = Normalizer.normalize(inputFirstName.getText() + " " + inputFirstSurname.getText() + " " + inputSecondSurname.getText(), Normalizer.Form.NFD);
fullNameNormalized = fullNameNormalized.replaceAll("[^\\p{ASCII}]", "");
fullNameNormalized = fullNameNormalized.toLowerCase();
String searchHelper = fullNameNormalized + " " + email + " " + phone;
因此,它基本上是一个较长的字符串,包含小写的所有用户信息,因此当我进行查询时,它看起来像这样:
String searchParams = searchText.getText().toString().toLowerCase().trim();
ParseQuery<ParseUser> newSearch = ParseUser.getQuery();
newSearch.whereContains("search_helper", searchParams);
在大多数情况下,这是可行的。 例如,如果我尝试搜索“约翰·桑切斯·史密斯”,它将正确返回“约翰·桑切斯·史密斯”作为搜索结果。 但是,如果我搜索“约翰·史密斯”,它将找不到他,因为该列未完全按照该顺序包含它。 有谁知道解决方法吗?
谢谢你的时间
无法搜索“ john smith”,因为contains表示只能搜索字符串的一部分,该部分必须在一起。 对此我感到抱歉。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.