慕蓋茨4494581
2023-07-06 14:56:18
我正在構建 javascript 服務,我想從“集合名稱”和“文檔 ID 數組”的輸入中從 firestore 獲取所有子集合文檔詳細信息。請求有效負載調用我的服務:{root_collection_name: "root_collection","msgId": ['11','22','33','66'],"subcollection_name": "message"}我需要搜索所有此msgId 的所有子集合(所有文檔的通用名稱)文檔。我的 firestore 結構如下所示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"的數據,其他值應發送 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貢獻1887條經驗 獲得超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。當您向模型添加較新的子集合時,如果它們不是同一類型的“消息”,您可以選擇不同的名稱。
添加回答
舉報
0/150
提交
取消