結果の順序を維持しながら、複数の Firestore クエリをローカルでマージするにはどうすればよいですか?

Mary-Kate Olsen
リリース: 2024-11-08 17:49:02
オリジナル
654 人が閲覧しました

How can I merge multiple Firestore queries locally while preserving the order of the results?

Firestore クエリをローカルでマージする

複数の Firestore クエリをローカルでマージすることは、特に結果の正しい順序を維持しようとする場合に困難になることがあります。ドキュメントの順序を維持しながらクエリを効率的にマージするための包括的なガイドは次のとおりです。

whenAllSuccess() を使用したクエリのマージ

2 つのクエリをマージして結果の順序を保持するには、whenAllSuccess() メソッドの使用を検討してください。 Tasks クラスから:

FirebaseFirestore rootRef = FirebaseFirestore.getInstance();
Query firstQuery = rootRef...
Query secondQuery = rootRef...

Task firstTask = firstQuery.get();
Task secondTask = secondQuery.get();

Task combinedTask = Tasks.whenAllSuccess(firstTask, secondTask).addOnSuccessListener(new OnSuccessListener<List<Object>>() {
    @Override
    public void onSuccess(List<Object> list) {
         // Iterate over the list to access the merged results in the order of the tasks
    }
});
ログイン後にコピー

whenAllSuccess() メソッドは、提供されたすべてのタスクが成功した場合に、正常に完了した単一のタスクを返します。この場合、list パラメーターには、各要素がクエリの順序に対応するスナップショット リストのリストが含まれます。

ContinueWith() を使用したクエリのマージ

クエリをマージするための別のオプションは、使用することです。 continueWith() メソッド。タスクを連鎖させることができます。

firstQuery.get().continueWith(new Continuation<QuerySnapshot, Object>() {
    @Override
    public Object then(@NonNull Task<QuerySnapshot> task) throws Exception {
        QuerySnapshot firstResults = task.getResult();

        // Perform any additional necessary operations with the first results

        // Execute the second query and chain it to the continuation
        return secondQuery.get().continueWith(new Continuation<QuerySnapshot, Object>() {
            @Override
            public Object then(@NonNull Task<QuerySnapshot> task) throws Exception {
                QuerySnapshot secondResults = task.getResult();

                List<DocumentSnapshot> mergedResults = new ArrayList<>();
                mergedResults.addAll(firstResults.getDocuments());
                mergedResults.addAll(secondResults.getDocuments());

                // Return the merged results
                return mergedResults;
            }
        });
    }
}).addOnSuccessListener(new OnSuccessListener<Object>() {
    @Override
    public void onSuccess(Object result) {
        // Cast the result to a List<DocumentSnapshot> and access the merged results
    }
});
ログイン後にコピー

この例では、最初のクエリの結果が取得され、必要な操作が実行されます。次に、2 番目のクエリが実行され、結果が最初の結果セットとマージされます。

パフォーマンスに関する考慮事項

どちらのアプローチも、アプリケーションのパフォーマンスに異なる影響を与える可能性があります。 whenAllSuccess() はすべてのクエリを同時に実行します。両方のクエリのパフォーマンス プロファイルが類似している場合、より効率的になります。 continueWith() はクエリを順番に実行します。これは、一方のクエリが他方のクエリよりも大幅に遅い場合に有益です。最終的に、最適なアプローチは、ユースケースの特定の要件によって異なります。

以上が結果の順序を維持しながら、複数の Firestore クエリをローカルでマージするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート