[英]How to retrieve list of model objects from firebase databse
Model Class
public String id;
public String total;
public List<CartModel> orderList;
public String currentDate;
public String orderBy;
我想獲取這些對象,但不幸的是不能這樣做。 我正在我的適配器 class 中訪問此列表,如下所示,但獲得 null 值。
protected void onBindViewHolder(@NonNull final OrderHolder holder, int position, @NonNull Orders model) {
List<CartModel> list = new ArrayList<>();
list = model.getOrderList();
Log.i("Orders", list+"");
holder.dateTime.setText(model.getCurrentDate());
holder.grandTotal.setText("Total "+model.getTotal());
holder.orderBy.setText(model.getOrderBy());
}
請為我提供一個有效的解決方案
Java 代碼中的字段名稱與 JSON 中的屬性名稱不匹配。
要使它們匹配,請更改:
public List<CartModel> orderList;
至:
public List<CartModel> orderItems;
String userid="your unique id";
String orderid="your unique id";
DatabaseReference database=FirebaseDatabase.getInstance().getReference()
databse.child("yourroot")
.child("Users")
.child(userid)
.child("Orders")
.child(orderid)
.child("orderItems")
.addValueEventListener(new ValueEventListener {
@Override
void onCancelled(@NonNull DatabaseError error) {
//handle error as per your requirement
}
@Override
void onDataChange(@NonNull DataSnapshot snapshot) {
YourModel model=snapshot.getValue(YourModel.class)
//use the model or add to adapter payload and notify it on mainthread
}
})
注意:如果您的 model class 不是一個合適的 class 來保存來自 DB 的值,您可能會得到DatabaseException
。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.