[英]Firebase Android - Check if value is already exists
我需要检查数据库中是否已存在该值的帮助,以便用户在更新它时无法将其更改为相同的数字,例如唯一ID
我一直在寻找解决方案的时间,但找不到任何有效的方法。
为此,建议您创建另一个名为userIds
节点。 每次创建新用户时,只需在此新部分中添加用户ID。 这个新部分应如下所示:
Firebase-root
--- userIds
--- Id101: true
--- Id102: true
然后,只需在该新节点节点上放置一个侦听器,并在dataSnapshot对象上使用exist exists()
方法即可。
按照建议,您应该拥有一个数据结构,一个索引列表,为此,为什么呢? 因为当您拥有大量此类ID时,这将是一个更好的查询。 但是,我认为您想要做的是对先前建议的补充。
您要做的是使用单个事件侦听器,如果datasnapshot不为null,则该值存在。 关键是查询所需的ID:
DatabaseReference root = FirebaseDatabase.getInstance.getReference();
DatabaseReference reference = root.child("Test").oderByChild("ID").equalsTo(someId);
reference.addSingleValueEventListener(new ValueEventListener() {
@Override
public void onDataChange(DataSnapshot dataSnapshot) {
if (dataSnaphot != null) {
//This means the value exist, you could also dataSnaphot.exist()
}
}
//More auto generated code
);
dataSnapshot
是一堆对象,因为查询可以匹配多个结果。 如果需要每个值,则可以在其中进行迭代:
public void onDataChange(DataSnapshot dataSnapshot) {
if (dataSnaphot != null) {
for (DataSnapshot children : dataSnaphot.getChildrens()) {
YourModel yourModel = children.getValue(YourModel.class);
}
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.