recuperar query guardar example datos consultas child android firebase firebase-database firebase-realtime-database groupchat

guardar - query firebase android



cómo obtener toda la lista secundaria de Firebase android (14)

Quiero toda la lista de niños de Firebase en Android.

He implementado este código pero no funciona.

mFirebaseRef = new Firebase(FIREBASE_URL); mFirebaseRef.addValueEventListener(new ValueEventListener() { @Override public void onDataChange(DataSnapshot dataSnapshot) { List<String> td = (ArrayList<String>) dataSnapshot.getValue(); //notifyDataSetChanged(); } @Override public void onCancelled(FirebaseError firebaseError) { } });


Usa GenericTypeIndicator para obtener la lista de nodos secundarios de Firebase ArrayList estructurada DataBase

//Start of Code Firebase ref = new Firebase(FIREBASE_URL); ref.addValueEventListener(new ValueEventListener(){ @Override public void onDataChange(DataSnapshot snapshot){ GenericTypeIndicator<List<YourClassName>> t = new GenericTypeIndicator<List<YourClassName>>{}; List<YourClassName> messages = snapshot.getValue(t); Log.d("Get Data Size", messages.size()); } } @Override public void onCancelled(FirebaseError firebaseError){ Log.e("The read failed: ",firebaseError.getMessage()); } });


En mi caso, solo la solución dada funcionó bien.

Captura de pantalla de la estructura Firebase ArrayList :

Cómo obtener una lista completa de Firebase desde DataSnapshot .

GenericTypeIndicator<Map<String, List<Education>>> genericTypeIndicator = new GenericTypeIndicator<Map<String, List<Education>>>() {}; Map<String, List<Education>> hashMap = dataSnapshot.getValue(genericTypeIndicator); for (Map.Entry<String,List<Education>> entry : hashMap.entrySet()) { List<Education> educations = entry.getValue(); for (Education education: educations){ Log.i(TAG, education.Degree); } }

Education.java: (clase de modelo).

public class Education implements Serializable{ public String Degree; public String Result; }

Espero que esto funcione bien.


Espero que debajo del código funcione

Firebase ref = new Firebase(FIREBASE_URL); ref.addValueEventListener(new ValueEventListener() { @Override public void onDataChange(DataSnapshot snapshot) { Log.e("Count " ,""+snapshot.getChildrenCount()); for (DataSnapshot postSnapshot: snapshot.getChildren()) { <YourClass> post = postSnapshot.getValue(<YourClass>.class); Log.e("Get Data", post.<YourMethod>()); } } @Override public void onCancelled(FirebaseError firebaseError) { Log.e("The read failed: " ,firebaseError.getMessage()); } });


Firebase almacena una secuencia de valores en este formato:

"-K-Y_Rhyxy9kfzIWw7Jq": "Value 1" "-K-Y_RqDV_zbNLPJYnOA": "Value 2" "-K-Y_SBoKvx6gAabUPDK": "Value 3"

Si así es como los tienes, estás obteniendo el tipo incorrecto. La estructura anterior se representa como un Map , no como una List :

mFirebaseRef = new Firebase(FIREBASE_URL); mFirebaseRef.addValueEventListener(new ValueEventListener() { @Override public void onDataChange(DataSnapshot dataSnapshot) { Map<String, Object> td = (HashMap<String,Object>) dataSnapshot.getValue(); List<Object> values = td.values(); //notifyDataSetChanged(); } @Override public void onCancelled(FirebaseError firebaseError) { } });


Funciona de maravilla

final DatabaseReference senderDb = FirebaseDatabase.getInstance().getReference(Constant.NODE_MESSAGE).child(myId + "_" + otherId); senderDb.addValueEventListener(new ValueEventListener() { @Override public void onDataChange(DataSnapshot dataSnapshot) { Map<String, Object> td = (HashMap<String,Object>) dataSnapshot.getValue(); for (DataSnapshot childDataSnapshot : dataSnapshot.getChildren()) { DatabaseReference objRef = senderDb.child( childDataSnapshot.getKey()); Map<String,Object> taskMap = new HashMap<String,Object>(); taskMap.put("is_read", "1"); objRef.updateChildren(taskMap); //should I use setValue()...? Log.v("Testing",""+ childDataSnapshot.getKey()); //displays the key for the node } //notifyDataSetChanged(); } @Override public void onCancelled(DatabaseError databaseError) { } });


Guardar y recuperar datos desde Firebase (en desuso ver.2.2.2)

Firebase fb_parent = new Firebase("YOUR-FIREBASE-URL/"); Firebase fb_to_read = fb_parent.child("students/names"); Firebase fb_put_child = fb_to_read.push(); // REMEMBER THIS FOR PUSH METHOD //INSERT DATA TO STUDENT - NAMES I Use Push Method fb_put_child.setValue("Zacharia"); //OR fb_put_child.setValue(YOUR MODEL) fb_put_child.setValue("Joseph"); //OR fb_put_child.setValue(YOUR MODEL) fb_put_child.setValue("bla blaaa"); //OR fb_put_child.setValue(YOUR MODEL) //GET DATA FROM FIREBASE INTO ARRAYLIST fb_to_read.addValuesEventListener....{ public void onDataChange(DataSnapshot result){ List<String> lst = new ArrayList<String>(); // Result will be holded Here for(DataSnapshot dsp : result.getChildren()){ lst.add(String.valueOf(dsp.getKey())); //add result into array list } //NOW YOU HAVE ARRAYLIST WHICH HOLD RESULTS for(String data:lst){ Toast.make(context,data,Toast.LONG_LENGTH).show; } } }


Hice algo como esto:

Firebase ref = new Firebase(FIREBASE_URL); ref.addValueEventListener(new ValueEventListener() { @Override public void onDataChange(DataSnapshot snapshot) { Map<String, Object> objectMap = (HashMap<String, Object>) dataSnapshot.getValue(); List<Match> = new ArrayList<Match>(); for (Object obj : objectMap.values()) { if (obj instanceof Map) { Map<String, Object> mapObj = (Map<String, Object>) obj; Match match = new Match(); match.setSport((String) mapObj.get(Constants.SPORT)); match.setPlayingWith((String) mapObj.get(Constants.PLAYER)); list.add(match); } } } @Override public void onCancelled(FirebaseError firebaseError) { } });


Necesita escribir un Deserializador personalizado y luego hacer un bucle y obtener los valores del hasmap.

Deserializador personalizado: -

public class UserDetailsDeserializer implements JsonDeserializer<AllUserDetailsKeyModel> { /* bebebejunskjd:{ "email": "[email protected]", "mobileNum": "12345678", "password": "1234567", "username": "akhil"}*/ @Override public AllUserDetailsKeyModel deserialize(JsonElement json, Type typeOfT, JsonDeserializationContext context) throws JsonParseException { final JsonObject jsonObject = json.getAsJsonObject(); Gson gson = new Gson(); Type AllUserDetailsResponseModel = new TypeToken<HashMap<String, AllUserDetailsResponseModel>>(){}.getType(); HashMap<String, AllUserDetailsResponseModel> user = gson.fromJson(jsonObject, AllUserDetailsResponseModel); AllUserDetailsKeyModel result = new AllUserDetailsKeyModel(); result.setResult(user); return result; } }

El código en los comentarios es mi modelo de objetos y debe reemplazar AllUserDetailsKeyModel con su clase de modelo y agregar esto al resto del cliente como se muestra a continuación:

private Converter.Factory createGsonConverter() { GsonBuilder gsonBuilder = new GsonBuilder(); gsonBuilder.registerTypeAdapter(AllUserDetailsKeyModel.class, new UserDetailsDeserializer()); Gson gson = gsonBuilder.create(); return GsonConverterFactory.create(gson); }

Este es el Convertidor personalizado para Retrofit.

En su onResponse simplemente realiza un bucle con hasmaps y obtiene valor por clave y mi clase de modelo se ve a continuación:

public class AllUserDetailsKeyModel { private Map<String, AllUserDetailsResponseModel> result; public Map<String, AllUserDetailsResponseModel> getResult() { return result; } public void setResult(Map<String, AllUserDetailsResponseModel> result) { this.result = result; } }

probablemente necesites dar un Tipo T donde T es tu Tipo de datos y mi modelo consiste solo en un hashmap y getters y setters para eso.

Y finalmente configure Custom Convertor para .addConverterFactory(createGsonConverter()) como se muestra a continuación: - .addConverterFactory(createGsonConverter())

Avísame si necesitas más aclaraciones.


Su problema es por qué su código no funciona.

este es tu código:

Firebase ref = new Firebase(FIREBASE_URL); ref.addValueEventListener(new ValueEventListener() { @Override public void onDataChange(DataSnapshot snapshot) { Log.e("Count " ,""+snapshot.getChildrenCount()); for (DataSnapshot postSnapshot: snapshot.getChildren()) { <YourClass> post = postSnapshot.getValue(<YourClass>.class); Log.e("Get Data", post.<YourMethod>()); } } @Override public void onCancelled(FirebaseError firebaseError) { Log.e("The read failed: " ,firebaseError.getMessage()); } })

te pierdes lo más simple: getChildren()

FirebaseDatabase db = FirebaseDatabase.getInstance(); DatabaseReference reference = FirebaseAuth.getInstance().getReference("Donald Trump"); reference.addValueEventListener(new ValueEventListener() { @Override public void onDataChange(DataSnapshot dataSnapshot) { int count = (int) dataSnapshot.getChildrenCount(); // retrieve number of childrens under Donald Trump String[] hairColors = new String[count]; index = 0; for (DataSnapshot datas : dataSnapshot.getChildren()){ hairColors[index] = datas.getValue(String.class); } index ++ for (int i = 0; i < count; i++) Toast(MainActivity.this, "hairColors : " + hairColors[i], toast.LENGTH_SHORT).show(); } } @Override public void onCancelled(DatabaseError databaseError) { } });


como dijo Frank, Firebase almacena la secuencia de valores en el formato de "key": "Value" que es una estructura de Mapa

para obtener la Lista de esta secuencia, tienes que

  1. Inicialice GenericTypeIndicator con HashMap of String y su objeto .
  2. obtener el valor de DataSnapShot como GenericTypeIndicator en Map .
  3. Inicialice ArrayList con valores HashMap .

GenericTypeIndicator<HashMap<String, Object>> objectsGTypeInd = new GenericTypeIndicator<HashMap<String, Object>>() {}; Map<String, Object> objectHashMap = dataSnapShot.getValue(objectsGTypeInd); ArrayList<Object> objectArrayList = new ArrayList<Object>(objectHashMap.values());

Funciona bien para mí, espero que ayude.


mDatabase.child("token").addListenerForSingleValueEvent(new ValueEventListener() { @Override public void onDataChange(DataSnapshot dataSnapshot) { for (DataSnapshot snapshot:dataSnapshot.getChildren()) { String key= snapshot.getKey(); String value=snapshot.getValue().toString(); } } @Override public void onCancelled(DatabaseError databaseError) { Toast.makeText(ListUser.this,databaseError.toString(),Toast.LENGTH_SHORT).show(); } });

Solo funciona si el niño no tiene SubChild


**Add value event method** @Override public void onDataChange(DataSnapshot dataSnapshot) { for (DataSnapshot postSnapshot : dataSnapshot.getChildren()) { User user = postSnapshot.getValue(User.class); list.add(user); } for (int i=0;i<list.size();i++) { Log.e("Name",list.get(i).getname()); Log.e("Phone",list.get(i).getphone()); } } @Override public void onCancelled(FirebaseError firebaseError) { Log.e("error",firebaseError.getMessage()); } });

Modelo de clase

Usuario de clase {

String name; String phone; public String getname() { return name; } public void setname(String name) { this.name = name; } public String getphone() { return phone; } public void setphone(String phone) { this.phone = phone; }

}

Enlace de lista

List<User> list= new ArrayList <>();

este trabajo para ti


ArrayList<String> keyList = new ArrayList<String>(); mKeyRef.addValueEventListener(new ValueEventListener() { @Override public void onDataChange(DataSnapshot dataSnapshot) { for (DataSnapshot childDataSnapshot : dataSnapshot.getChildren()) { String temp = childDataSnapshot.getKey(); keyList.add(temp); i = keyList.size(); } } @Override public void onCancelled(DatabaseError databaseError) { throw databaseError.toException(); } });

Este código está funcionando bien para agregar todas las claves de firebase en la lista de arrays, puede hacerlo con los valores de firebase, de otros valores estáticos.


FirebaseDatabase mFirebaseDatabase = FirebaseDatabase.getInstance(); DatabaseReference databaseReference = mFirebaseDatabase.getReference(FIREBASE_URL); databaseReference.addValueEventListener(new ValueEventListener() { @Override public void onDataChange(DataSnapshot dataSnapshot) { for (DataSnapshot childDataSnapshot : dataSnapshot.getChildren()) { Log.v(TAG,""+ childDataSnapshot.getKey()); //displays the key for the node Log.v(TAG,""+ childDataSnapshot.child(--ENTER THE KEY NAME eg. firstname or email etc.--).getValue()); //gives the value for given keyname } } @Override public void onCancelled(DatabaseError databaseError) { } });

¡Espero eso ayude!