使用正确的结果排序在本地合并两个 Firestore 查询
在 Firestore 中,如果缺少逻辑 OR 运算符,可能需要在本地合并多个查询才能检索所需的数据。这引起了对维护结果正确顺序的担忧,特别是在使用 orderBy 以特定顺序检索记录时。
要解决此问题,一种方法是将第二个查询放置在第一个查询的 onSuccessListener 中。但是,从性能角度来看,这可能效率较低。
建议的替代方案是利用 Tasks.whenAllSuccess() 方法来合并查询并保留其顺序。通过遵循这种方法,您可以执行以下步骤:
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>>() { @Override public void onSuccess(List<object> list) { // Perform desired operations with your ordered results } });</object></list>
combinedTask 中的 onSuccess() 方法为您提供代表两个查询结果的对象列表,这些对象的排列顺序与已合并的任务。
或者,您可以考虑使用 Tasks.continueWith() 方法进行任务链接。 whenAllSuccess() 和 continueWith() 方法都提供了可靠的机制来合并任务和维护所需的结果顺序。请参阅 Firebase 官方文档了解更多信息。
以上是如何在本地合并两个 Firestore 查询并保留结果排序?的详细内容。更多信息请关注PHP中文网其他相关文章!

本文讨论了使用Maven和Gradle进行Java项目管理,构建自动化和依赖性解决方案,以比较其方法和优化策略。

本文使用Maven和Gradle之类的工具讨论了具有适当的版本控制和依赖关系管理的自定义Java库(JAR文件)的创建和使用。

本文讨论了使用咖啡因和Guava缓存在Java中实施多层缓存以提高应用程序性能。它涵盖设置,集成和绩效优势,以及配置和驱逐政策管理最佳PRA

本文讨论了使用JPA进行对象相关映射,并具有高级功能,例如缓存和懒惰加载。它涵盖了设置,实体映射和优化性能的最佳实践,同时突出潜在的陷阱。[159个字符]

Java的类上载涉及使用带有引导,扩展程序和应用程序类负载器的分层系统加载,链接和初始化类。父代授权模型确保首先加载核心类别,从而影响自定义类LOA


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

WebStorm Mac版
好用的JavaScript开发工具

Atom编辑器mac版下载
最流行的的开源编辑器

Dreamweaver Mac版
视觉化网页开发工具