我正在尝试从firebase
实时数据库中读取“特定”数据。我已经看到了从表中获取所有数据并通过它查找所需数据记录的示例,但这绝对不是推荐的安全做法。
以下是我保存数据的方式
private void saveInDatabase(String email)
{
// Write a message to the database
FirebaseDatabase database = FirebaseDatabase.getInstance();
DatabaseReference myRef = database.getReference("user");
String key = myRef.push().getKey();
User user = new User();
user.setCountry("United States");
user.setEmail(email);
user.setFirstName("John");
user.setLastName("Doh");
user.setGender("Male");
myRef.child(key).setValue(user);
}
那很好用。但现在我需要从user
表中检索数据记录,该表只属于John
。如果我用MySQL做这个,那就像select * from user where primaryKey =JOHN_PRYMARY_KEY
我试一试,检查下面。
database.getReference("user" + FirebaseAuth.getInstance().getCurrentUser().getUid());
我真的不确定如何从这里开始,我认为没有办法继续前进。请指教。
更新
我尝试了 peter haddad 和其他人的答案。当我尝试从DataSnapshot获取数据时,它会抛出NullPointerException。 OnDataChanged被解雇了。以下是我的数据库。
我尝试以3种不同的方式获取数据,请查看以下内容。
----没有1 ----
private void getUserData()
{
DatabaseReference reference = FirebaseDatabase.getInstance().getReference("user");
reference.orderByChild("email").equalTo(FirebaseAuth.getInstance().getCurrentUser().getEmail()).addListenerForSingleValueEvent(new ValueEventListener() {
@Override
public void onDataChange(DataSnapshot dataSnapshot) {
for(DataSnapshot datas: dataSnapshot.getChildren()){
String familyname=datas.child("familyName").getValue().toString();
}
}
@Override
public void onCancelled(DatabaseError databaseError) {
}
});
}
---- No 2 ----
private void getUserData()
{
FirebaseUser user=FirebaseAuth.getInstance().getCurrentUser();
String userid=user.getUid();
DatabaseReference reference = FirebaseDatabase.getInstance().getReference("user");
reference.child(userid).addListenerForSingleValueEvent(new ValueEventListener() {
@Override
public void onDataChange(DataSnapshot dataSnapshot) {
String email = dataSnapshot.getValue(User.class).getEmail();
String firstName = dataSnapshot.getValue(User.class).getFirstName();
Log.d("Datasnapshot",email+" "+firstName);
}
@Override
public void onCancelled(DatabaseError databaseError) {
}
});
}
---- No 3 ----
private void getUserData() {
FirebaseDatabase database = FirebaseDatabase.getInstance();
DatabaseReference myRef = database.getReference("user");
Query specific_user = myRef.child(FirebaseAuth.getInstance().getCurrentUser().getUid());
specific_user.addListenerForSingleValueEvent(
new ValueEventListener() {
@Override
public void onDataChange(DataSnapshot dataSnapshot) {
//here you will get the data
String email = dataSnapshot.getValue(User.class).getEmail();
String firstName = dataSnapshot.getValue(User.class).getFirstName();
Log.d("Datasnapshot", email + " " + firstName);
}
@Override
public void onCancelled(DatabaseError databaseError) {
}
});
}
这是我得到的错误。基于我使用的代码集,Null指针触发器的位置变得不同,正常行为。
rebaseauth D/NetworkSecurityConfig: No Network Security Config specified, using platform default
04-25 11:49:46.340 31202-31271/com.example.yohan.firebaseauth V/FA: Inactivity, disconnecting from the service
04-25 11:49:47.793 31202-32166/com.example.yohan.firebaseauth W/PersistentConnection: pc_0 - Using an unspecified index. Consider adding '".indexOn": "email"' at user to your security and Firebase Database rules for better performance
04-25 11:49:47.794 31202-31202/com.example.yohan.firebaseauth D/AndroidRuntime: Shutting down VM
04-25 11:49:47.794 31202-31202/com.example.yohan.firebaseauth E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.example.yohan.firebaseauth, PID: 31202
java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String java.lang.Object.toString()' on a null object reference
at com.example.yohan.firebaseauth.MainActivity$6.onDataChange(MainActivity.java:249)
at com.google.firebase.database.Query$1.onDataChange(Unknown Source)
at com.google.android.gms.internal.zzbmz.zza(Unknown Source)
at com.google.android.gms.internal.zzbnz.zzYj(Unknown Source)
at com.google.android.gms.internal.zzboc$1.run(Unknown Source)
at android.os.Handler.handleCallback(Handler.java:751)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:154)
at android.app.ActivityThread.main(ActivityThread.java:6682)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1520)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1410)
答案 0 :(得分:3)
您需要进行查询:
orderByChild("FirstName").equalTo(name);
DatabaseReference reference = FirebaseDatabase.getInstance().getReference("user");
reference.orderByChild("firstName").equalTo(name).addListenerForSingleValueEvent(new ValueEventListener() {
@Override
public void onDataChange(DataSnapshot dataSnapshot) {
for(DataSnapshot datas: dataSnapshot.getChildren()){
String familyname=datas.child("familyName").getValue().toString();
}
}
@Override
public void onCancelled(DatabaseError databaseError) {
}
});
假设你有这个数据库:
user
randomid
firstName: John
familyName: familyName_here
另一种方法是使用userid来检索数据,但正如我在问题中看到的那样,您使用push()
保存了随机ID。
您需要检索用户ID:
FirebaseUser user=FirebaseAuth.getInstance().getCurrentUser();
String userid=user.getUid();
然后将其添加到数据库中:
myRef.child(userid).setValue(user);
然后只为John检索数据:
FirebaseUser user=FirebaseAuth.getInstance().getCurrentUser();
String userid=user.getUid();
DatabaseReference reference = FirebaseDatabase.getInstance().getReference("user");
reference.child(userid).addListenerForSingleValueEvent(new ValueEventListener() {..}
答案 1 :(得分:1)
Query specific_user = myRef.child(FirebaseAuth.getInstance().getCurrentUser().getUid());
specific_user.addListenerForSingleValueEvent(
new ValueEventListener() {
@Override
public void onDataChange(DataSnapshot dataSnapshot) {
//here you will get the data
}
@Override
public void onCancelled(DatabaseError databaseError) {
}
});
答案 2 :(得分:0)
您必须从firebase收集响应到某些POJO类
关注链接:https://firebase.google.com/docs/database/admin/retrieve-data
正如您在onDataChange()中看到的那样,响应是在Post.class中收集的,这是POJO类。