如何在Firestore上查询字段中包含字典数组的位置?

发布于 2025-02-09 10:25:59 字数 1268 浏览 2 评论 0原文

我正在尝试从firestore中获取项目数据,这是我在firestore上的结构:

“在此处输入映像”

,这是我的代码:

FirestoreReferenceManager.rootProjects.whereField(
            FirebaseKeys.ProjectDetails.inviteData,
            arrayContains: [
                FirebaseKeys.ProjectDetails.otherUserId: userID,
                FirebaseKeys.ProjectDetails.inviteStatus: FirebaseKeys.ProjectDetails.pending
            ])

如果我没有isinvoiceAceCaccess firestore上的数据然后上面的代码工作正常,但是当我在firestore上添加该密钥时,请查询没有给我任何结果,我无法添加该密钥,因为它可以是truefalse

如果我使用以下代码,那么我将获得结果:

FirestoreReferenceManager.rootProjects.whereField(
            FirebaseKeys.ProjectDetails.inviteData,
            arrayContains: [
                FirebaseKeys.ProjectDetails.otherUserId: userID,
                FirebaseKeys.ProjectDetails.inviteStatus: FirebaseKeys.ProjectDetails.pending,
                FirebaseKeys.ProjectDetails.invoiceAccess: true
            ])

因此,我需要从firestore中的数据,而无需在我的查询中添加isinvoiceaccess

I am trying to fetch project data from FireStore and here is my structure on firestore:

enter image description here

And here is my code:

FirestoreReferenceManager.rootProjects.whereField(
            FirebaseKeys.ProjectDetails.inviteData,
            arrayContains: [
                FirebaseKeys.ProjectDetails.otherUserId: userID,
                FirebaseKeys.ProjectDetails.inviteStatus: FirebaseKeys.ProjectDetails.pending
            ])

If I don't have isInvoiceAccess data on firestore then above code is working fine but when I add that key on firestore then above query is not giving me any results and I can not add that key because it can be true or false.

If I use below code then I am getting the results:

FirestoreReferenceManager.rootProjects.whereField(
            FirebaseKeys.ProjectDetails.inviteData,
            arrayContains: [
                FirebaseKeys.ProjectDetails.otherUserId: userID,
                FirebaseKeys.ProjectDetails.inviteStatus: FirebaseKeys.ProjectDetails.pending,
                FirebaseKeys.ProjectDetails.invoiceAccess: true
            ])

So I want data from FireStore without adding isInvoiceAccess in my query.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

提赋 2025-02-16 10:25:59

ArrayContains操作仅检查数组中是否有确切的匹配,它无法检查部分匹配项。

用例的常见解决方法是为要查询的每个特定值/组合添加一个附加的数组字段。因此,在您的情况下,添加一个字段Invites_UID_AND_STATUS只有每个两个值,然后在此查询中使用

The arrayContains operation only checks whether there is exact match in the array, it cannot check for partial matches.

The common workaround for your use-case is to add an additional array field for each specific values/combination of values that you want to query on. So in your case, add a field invites_uid_and_status with just those two values for each, and then use that for this query.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文