我想编写一个查询,以便使用edittext过滤数据,下面的代码确实有效,但会带来所有不需要的搜索数据。你能帮我么? JSON对象如下:我想过滤掉的数据是用户名
public class SearchActivity extends AppCompatActivity {
ListView searchList;
DatabaseReference databaseReference;
FirebaseListAdapter<SearchDetails> listAdapter;
String search;
EditText editTextSearch;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_search);
searchList = (ListView) findViewById(R.id.listViewSearch);
databaseReference = FirebaseDatabase.getInstance().getReference().child("Search Users");
editTextSearch = (EditText) findViewById(R.id.editTextSearch);
editTextSearch.addTextChangedListener(new TextWatcher() {
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
}
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
}
@Override
public void afterTextChanged(Editable s) {
search = editTextSearch.getText().toString();
if (search.equals("")){
searchList.setAdapter(null);
}else{
searchList.setAdapter(listAdapter);
}
}
});
Query query = databaseReference.startAt(search).endAt(search+"~").limitToFirst(10);
listAdapter = new FirebaseListAdapter<SearchDetails>(
this,
SearchDetails.class,
R.layout.search_layout,
query
) {
@Override
protected void populateView(View v, SearchDetails model, int position) {
TextView username = (TextView) v.findViewById(R.id.textViewUsername);
username.setText(model.getUsername());
TextView name = (TextView) v.findViewById(R.id.textViewName);
name.setText(model.getName());
}
};
}
}
答案 0 :(得分:1)
为了解决这个问题,我们需要了解Firebase的一些内容,许多开发人员可能会忽略这些内容。
我认为您手边的问题是“EditText
允许用户搜索用户的用户名。
我建议你解决这个问题的方法是扁平化数据结构,如此
您可以在usernames
数组中包含对象。每个对象的键都是username
,值是另一个empty-key : ""
的对象,如此。
然后你可以拥有另一个users
数组,其中密钥为usernames
,其余数据作为其下的对象存在。
现在,您可以轻松地在usernames
上运行过滤查询,而无需担心在该查询中获取不必要数据的开销。
一旦您知道选择了哪个username
,就可以查询users
以从数组中获取精确的user
。
答案 1 :(得分:0)
查询query = databaseReference.orderByChild(“username”)。startAt(search).endAt(search +“〜”)。limitToFirst(10);