我正在为我的Android应用程序使用Firebase数据库。我在应用程序中实现了搜索功能。在我的数据库中,仅当我以大写字母“ A”开始搜索时,才会显示每个以“ A”开头的标题。当我输入小写字母“ a”时,未显示任何结果。我也想启用搜索小写字母的变体形式。请帮帮我。谢谢。这是我的搜索代码。
private void firebaseUserSearch(String searchText) { Toast.makeText(Idioms.this, "Started Search", Toast.LENGTH_LONG).show(); Query firebaseSearchQuery = mUserDatabase.orderByChild("Title").startAt(searchText).endAt(searchText + "\uf8ff"); FirebaseRecyclerAdapter<Blog,BlogViewHolder> firebaseRecyclerAdapter = new FirebaseRecyclerAdapter<Blog, BlogViewHolder>( Blog.class, R.layout.bank_row, BlogViewHolder.class, firebaseSearchQuery ) { @Override protected void populateViewHolder(BlogViewHolder viewHolder, Blog model, int position) { viewHolder.setDetails(getApplicationContext(), model.getTitle(), model.getDescription(), model.getExample()); } }; mResultList.setAdapter(firebaseRecyclerAdapter); }
有两种方法可以解决此问题。第一个方法是使用方法甚至从一开始就将项目名称以小写形式存储在数据库中toLowerCase()。因此,如果您想通过小写字母搜索名称,将可以很好地工作。然后,如果您想在活动中不使用名称,并且要大写第一个字母,则只需使用以下代码行:
toLowerCase()
String firstLetterCapital = lowerCaseItemName.substring(0, 1).toUpperCase() + lowerCaseItemName.substring(1);
因此,如果item使用上述代码,您的商品名称为,则结果将是:Item。
item
Item
第二种方法是将商品的小写名称存储为商品的属性,如下所示:
Firebase-root | --- items | --- ItemIdOne | --- itemName: Item | --- itemToLowerCase: item
然后,可以使用如下查询来创建搜索:
DatabaseReference rootRef = FirebaseDatabase.getInstance().getReference(); DatabaseReference itemsRef = rootRef.child("items"); Query query = itemsRef.orderByChild("itemToLowerCase").startAt(itemName.toLowerCase());