„Wenn ein Arbeiter seine Arbeit gut machen will, muss er zuerst seine Werkzeuge schärfen.“ – Konfuzius, „Die Gespräche des Konfuzius. Lu Linggong“
Titelseite > Programmierung > Wie kann ich in Node.js effizient ein zufälliges Produkt aus einem großen Firebase-Datensatz abrufen?

Wie kann ich in Node.js effizient ein zufälliges Produkt aus einem großen Firebase-Datensatz abrufen?

Veröffentlicht am 09.11.2024
Durchsuche:770

 How to Efficiently Retrieve a Random Product from a Large Firebase Dataset in Node.js?

Wie rufe ich ein eindeutiges Zufallsprodukt in Node Firebase ab?

Firebase bietet flexible Datenstrukturen, die es Ihnen ermöglichen, Daten hierarchisch zu speichern. In einigen Szenarien verfügen Sie möglicherweise über eine große Anzahl von Datensätzen, benötigen jedoch nur einen einzigen eindeutigen und zufälligen Datensatz. Dieser Artikel führt Sie durch zwei Ansätze, um dies in Node Firebase zu erreichen.

Klassischer Ansatz: Herunterladen aller Datensätze

Angenommen, Ihre Datenbankstruktur ähnelt der folgenden:

Firebase-root
   |
   --- products
         |
         --- productIdOne
         |      |
         |      --- name: "gjwj"
         |      |
         |      --- category: "hreggrrg"
         |      |
         |      --- location: "vjhiwehifwe"
         |      |
         |      --- price: 44
         |      |
         |      --- color: "fassaf"
         |
         --- productIdTwo
         |      |
         |      --- name: "uygfwh"
         |      |
         |      --- category: "hhhjwwwom"
         |      |
         |      --- location: "pervrr"
         |      |
         |      --- price: 33
         |      |
         |      --- color: "yrtrr"
         |
         --- //And so on

Um ein zufälliges Produkt abzurufen, können Sie den folgenden Code implementieren:

var listView = (ListView) findViewById(R.id.list_view);
var arrayAdapter = new ArrayAdapter(context, android.R.layout.simple_list_item_1, randomProductList);
listView.setAdapter(arrayAdapter);
var rootRef = FirebaseDatabase.getInstance().getReference();
var productsRef = rootRef.child("products");
var valueEventListener = new ValueEventListener() {
    @Override
    public void onDataChange(DataSnapshot dataSnapshot) {
        var productList = new ArrayList();
        for(var ds : dataSnapshot.getChildren()) {
            var name = ds.child("name").getValue(String.class);
            productList.add(name);
        }

        var productListSize = productList.size();
        var randomProductList = new ArrayList();

        randomProductList.add(new Random().nextInt(productListSize)); 
        arrayAdapter.notifyDatasetChanged();
    }

    @Override
    public void onCancelled(DatabaseError databaseError) {
        Log.d(TAG, "Error: ", task.getException()); //Don't ignore errors!
    }
};
productsRef.addListenerForSingleValueEvent(valueEventListener);

Indem Sie alle Produkte durchlaufen, können Sie eine Liste erstellen und einen zufälligen Index innerhalb dieser Liste generieren, der das ausgewählte Produkt darstellt.

Optimiert Ansatz: Vollständiges Herunterladen von Datensätzen vermeiden

Um den Datenabruf zu minimieren, können Sie Ihre Datenbank wie folgt umstrukturieren:

Firebase-root
   |
   --- products
   |     |
   |     --- productIdOne
   |     |      |
   |     |      --- //details
   |     |
   |     --- productIdTwo
   |            |
   |            --- //details
   |      
   --- productIds
          |
          --- productIdOne: true
          |
          --- productIdTwo: true
          |
          --- //And so on

Hier erstellen Sie einen separaten Knoten namens „productIds“, der nur die IDs Ihrer Produkte enthält. So rufen Sie ein zufälliges Produkt ab:

var rootRef = FirebaseDatabase.getInstance().getReference();
var productIdsRef = rootRef.child("productIds");
var valueEventListener = new ValueEventListener() {
    @Override
    public void onDataChange(DataSnapshot dataSnapshot) {
        var productIdsList = new ArrayList();
        for(var ds : dataSnapshot.getChildren()) {
            var productId = ds.getKey();
            productIdsList.add(productId);
        }

        var productListSize = productList.size();
        var randomProductList = new ArrayList(););

        var productIdRef = rootRef.child("products").child(productIdsList.get(new Random().nextInt(int productListSize));
        var eventListener = new ValueEventListener() {
            @Override
            public void onDataChange(DataSnapshot dataSnapshot) {
                var name = dataSnapshot.child("name").getValue(String.class);
                Log.d("TAG", name);
            }

            @Override
            public void onCancelled(DatabaseError databaseError) {
                Log.d(TAG, "Error: ", task.getException()); 
            }
        };
        productIdRef.addListenerForSingleValueEvent(eventListener);
    }

    @Override
    public void onCancelled(DatabaseError databaseError) {
        Log.d(TAG, "Error: ", task.getException()); 
    }
};
productIdsRef.addListenerForSingleValueEvent(valueEventListener);

Indem Sie zuerst die Produkt-ID abrufen, können Sie dann nach dem spezifischen Produkt fragen, was zu einem effizienteren und gezielteren Abrufprozess führt.

Neuestes Tutorial Mehr>

Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.

Copyright© 2022 湘ICP备2022001581号-3