我正在开发要在Firebase数据库中存储用户的唯一ID的android应用程序,因此要实现这一点,我创建了一个名为“ Users”的根,并将所有用户的唯一ID存储在该根中。
因此,为了检查唯一性,我必须遍历“用户”的每个子级,并且在检查了唯一性之后,我将把uniqueID添加到“用户”根目录中,或通知用户uniqueId不可用。
当我检查唯一性时,它是在OnChildAdded事件发生之前执行条件语句(如果/其他),如何在OnChildAdded事件发生之后执行一些代码(在我的代码中提到)
我的密码
postBtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
if(!uniqueIdText.getText().toString().trim().equals("")) {
uniqueness = true;
users.addChildEventListener(new ChildEventListener() {
@Override
public void onChildAdded(DataSnapshot dataSnapshot, String s) {
if (dataSnapshot.getKey().equals(uniqueIdText.getText().toString().trim()))
uniqueness = false;
}
@Override
public void onChildChanged(DataSnapshot dataSnapshot, String s) {
}
@Override
public void onChildRemoved(DataSnapshot dataSnapshot) {
}
@Override
public void onChildMoved(DataSnapshot dataSnapshot, String s) {
}
@Override
public void onCancelled(DatabaseError databaseError) {
}
});
}
else if(uniqueIdText.getText().toString().trim().equals("") )
Toast.makeText(LoginActivity.this,"Please enter id",Toast.LENGTH_LONG).show();
//======================How to execute it(code below) after occurrence of OnChildAdded event====================
if (uniqueness){
DatabaseReference usersInfo = users.child(uniqueIdText.getText().toString().trim());
startActivity(new Intent(LoginActivity.this, MainActivity.class));
}
else{
if(!uniqueIdText.getText().toString().trim().equals(""))
Toast.makeText(LoginActivity.this, "ID not available, Please enter a new one", Toast.LENGTH_SHORT).show();
}
}
});
最佳答案
无法知道何时已调用所有onChildAdded
事件。但是您可以知道何时使用ValueEventListener
同步了数据库中的第一个数据。
但是在这种情况下,我强烈建议您采用其他方法。下载所有UID以检查是否存在一个值的效率非常低,并且无法扩展。而是将侦听器附加到您要查找的特定UID。如果该值存在,则将获得该值。如果不存在,您将获得一个空快照:
users.child(uniqueIdText.getText().toString()).addSingleValueEventListener(@Override
public void onDataChange(DataSnapshot dataSnapshot) {
if (dataSnapshot.exists()) {
uniqueness = false;
}
else {
uniqueness = true;
}
...
}
@Override
public void onCancelled(DatabaseError databaseError) {
Log.w(TAG, "onCancelled", databaseError.toException());
// ...
}
};