【发布时间】:2017-02-10 09:32:33
【问题描述】:
Android 和 Firebase 的新手,开发了两个应用程序,其中一个将数据发送到 firebase 数据库,另一个将从数据库中检索数据。
数据已成功添加到 firebase 控制台,但是当我在其他应用程序中检索数据时,只显示一个数据节点,但是当我通过调试代码检查时,所有数据都显示了,但在 textview 中只有一个节点显示出来。
以下是我检索代码的代码 -
public class MainActivity extends AppCompatActivity
implements NavigationView.OnNavigationItemSelectedListener {
TextView tv,tv1;
Button btn;
FirebaseDatabase database = FirebaseDatabase.getInstance();
DatabaseReference myRef = database.getReference("users");
private DatabaseReference mDatabase;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
if (!FirebaseApp.getApps(this).isEmpty()) {
// Not in crash process. Do your Remote Config init here.
System.out.println("ss");
}
tv = (TextView) findViewById(R.id.textView3);
tv1 = (TextView) findViewById(R.id.textView2);
mDatabase = FirebaseDatabase.getInstance().getReference();
btn = (Button) findViewById(R.id.button2);
btn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
ValueEventListener valueEventListener = myRef.addValueEventListener(new ValueEventListener() {
@Override
public void onDataChange(DataSnapshot snapshot) {
for (DataSnapshot postSnapshot : snapshot.getChildren()) {
User user = postSnapshot.getValue(User.class);
String string = "Name: " + user.getUsername() + "\n Number : " + user.getNumber() + "\n Age: " + user.getAge();
tv.setText(string);
}
}
@Override
public void onCancelled(DatabaseError databaseError) {
System.out.println("The read failed: " + databaseError.getMessage());
}
});
}
现在我想做的是在不同的文本视图中显示所有数据(一个用户一个文本视图)或者可以使用卡片视图(仍然需要研究)。
下面是firebase控制台数据的json
{
"users" : {
"Name1" : {
"age" : "18",
"number" : "1234678",
"username" : "Name1"
},
"Name2" : {
"age" : "20",
"number" : "99999999",
"username" : "Name2"
},
"Name3" : {
"age" : "22",
"number" : "8888888",
"username" : "Name3"
}
}
}
在应用程序的输出中,我只得到 -
Name: Name3
Number: 8888888
Age: 22
【问题讨论】:
标签: android firebase textview firebase-realtime-database android-cardview