第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機(jī)立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何從 firestore 中的文檔 ID 數(shù)組中獲取所有子集合文檔

如何從 firestore 中的文檔 ID 數(shù)組中獲取所有子集合文檔

慕蓋茨4494581 2023-07-06 14:56:18
我正在構(gòu)建 javascript 服務(wù),我想從“集合名稱”和“文檔 ID 數(shù)組”的輸入中從 firestore 獲取所有子集合文檔詳細(xì)信息。請求有效負(fù)載調(diào)用我的服務(wù):{root_collection_name: "root_collection","msgId": ['11','22','33','66'],"subcollection_name": "message"}我需要搜索所有此msgId 的所有子集合(所有文檔的通用名稱)文檔。我的 firestore 結(jié)構(gòu)如下所示collection:    document1:        subcollection:            document:                "val1":"red",                "val2":"blue",                "val3":"green"    document2:        subcollection:            document:                "val1":"apple",                "val2":"mango",                "val3":"grape"    document3:        ..............            ................例子:root_collection:    11:        aaa:            message:                "val1":"red",                "val2":"blue",                "val3":"green"    22:        bbb:            message:                "val1":"apple",                "val2":"mango",                "val3":"grape"                在這種情況下,我需要獲取firestore 中可用的msgId "11"、"22"的數(shù)據(jù),其他值應(yīng)發(fā)送 null。您能幫忙解決這個問題嗎?不確定我在這里缺少什么。這是我為此編寫的代碼。const input = {"root_collection_name": "root_collection","msgId": ['11','22','33','66'],"subcollection_name": "message"}    const test =  (input) => {    const query = firestore.collection(input.root_collection_name).where('id', 'array-contains-any', input.msgId);      query.get().then((querySnapshot) => {        querySnapshot.forEach((document) => {          document.ref.collection(input.subcollection_name).get().then((querySnapshot) => {            querySnapshot.forEach(doc => {              console.log('doc data',doc.data());            });          });        });      });     };test(input);
查看完整描述

1 回答

?
慕工程0101907

TA貢獻(xiàn)1887條經(jīng)驗(yàn) 獲得超5個贊

如果將頂級文檔的 ID 添加到子集合文檔中,則可以使用 collectionGroup。

因此,從您的示例中您將得到:

root_collection:

11:

? ? aaa:

? ? ? ? message:

? ? ? ? ? ? "root_id": "11", // <<-- new!

? ? ? ? ? ? "val1":"red",

? ? ? ? ? ? "val2":"blue",

? ? ? ? ? ? "val3":"green"

22:

? ? bbb:

? ? ? ? message:

? ? ? ? ? ? "root_id": "22", // <<-- new!

? ? ? ? ? ? "val1":"apple",

? ? ? ? ? ? "val2":"mango",

? ? ? ? ? ? "val3":"grape"

您可以使用以下方式查詢:


var msgs = firebase.firestore().collectionGroup('message')

? ? ? ? ? ? ?.where('root_id', 'in', ['11','22']);

注意:這將查詢所有名為 的子集合message。當(dāng)您向模型添加較新的子集合時,如果它們不是同一類型的“消息”,您可以選擇不同的名稱。


查看完整回答
反對 回復(fù) 2023-07-06
  • 1 回答
  • 0 關(guān)注
  • 135 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號